質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
XML

XMLは仕様の1つで、マークアップ言語群を構築するために使われています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

1回答

409閲覧

【python?】社内システムの設定データ(XML)を旧バージョンから新バージョンに移したい。

michaelkami

総合スコア0

XML

XMLは仕様の1つで、マークアップ言語群を構築するために使われています。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2022/12/15 16:27

編集2022/12/15 16:37

前提

python勉強はじめて、1週間です。
基本的なif文や、defを覚えたばかりでド初心者です。
google colabです。ローカルの開発環境なし。

xmlについてもほとんど何も知りません。
python,xml共に開発経験なしです。
pythonの勉強がてら、今会社でやってる業務を自動化して時間を作って、
できた時間を勉強に使うループを作れたら素敵だなと思ってます!

実現したいこと(後述)を実現するためのアプローチや、知っておくべき概念、
具体的な手法、望ましい開発環境など、アドバイスを求めております!!
質問として足りない情報があれば随時補足します(お手柔らかに;;)

実現したいこと

社内システムの設定データ(XML)を
法則に従って、旧バージョンから新バージョンに移行したいです。
社内システムのデータが膨大で、現状人間による目視でやっているため自動化できれば神です!!

【旧バージョン既存設定:例】

xml

1<data> 2 <A01> 3 <tb test="1"> 4 <class>新バージョンとタグ構造が一致するので、移したい値</class> 5 </tb> 6 <tb test="2"> 7 <class>新バージョンにtb test="2"タグが無いため無視</class> 8 </tb> 9 </A01> 10 <A02> 11 <tb test="1"> 12 <class>新バージョンにA02タグがないため無視</class> 13 </tb> 14 </A02> 15 <A03> 16 <abc>新バージョンにA03タグはあるが、中身がないためタグ構造ごと移行</abc> 17 <abc></abc> 18 </A003> 19</data>

【新バージョン初期値:例】

xml

1<data> 2 <A01> 3 <tb test="1"> 4 <class>初期値</class> 5 </tb> 6 </A01> 7 </A03> 8 <A04> 9 <tb test="1"> 10 <class>初期値</class> 11 </tb> 12 </A04> 13</data>

【データ移行完了後の新バージョン設定】

xml

1<data> 2 <A01> 3 <tb test="1"> 4 <class>A01タグ内の構造が新バージョンと一致するので、移したい値</class> 5 </tb> 6 </A01> 7 <A03> 8 <abc>新バージョン側にA03タグはあるが、中身がないためタグ構造ごとコピペ</abc> 9 <abc></abc> 10 </A003> 11 <A04> 12 <tb test="1"> 13 <class>初期値</class> 14 </tb> 15 </A04> 16</data>

----知りたいこと----

  • 旧バージョンxmlファイルから値を抽出して新バージョンxmlファイルに出力する方法
  • A01~A04の4パターンを場合分けする方法
  • 必要なソフトウェア、環境など

試したこと

構想段階です。試した方がいいことがあればアドバイスお願いします!

補足情報(FW/ツールのバージョンなど)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

質問にある3点についてコメントします(「丸投げ」の指摘がついていますが、一度試すなどして、具体的なエラーや課題を説明すると、回答も得られやすくなると思います)。

旧バージョンxmlファイルから値を抽出して新バージョンxmlファイルに出力する方法

Pythonには、XMLを操作する標準クラスxml.etree.ElementTreeがありますので、このクラスの操作の方法を調べるのが一案だと思います。

A01~A04の4パターンを場合分けする方法

質問から操作の条件が十分理解できていない気がしますが、分岐の例として、サンプルを書いてみます。

python

1import xml.etree.ElementTree as ET 2 3tree = ET.parse('input.xml') 4root = tree.getroot() 5 6# 例: (1) A03タグを削除, (2) test="1"を持つタグを削除 7for a_tag in root: 8 if a_tag.tag == 'A03': 9 root.remove(a_tag) 10 else: 11 for tb_tag in a_tag: 12 if tb_tag.attrib.get('test') == '1': 13 a_tag.remove(tb_tag) 14 15tree.write('output.xml', encoding='UTF-8')

必要なソフトウェア、環境など

「Google Colab」でも実行可能だと思いますが、XMLファイルのアップロードやダウンロードがある程度手間になると思いますので、ローカルにPythonの実行環境を作成することをオススメします。

Windowsの場合の一例です。

投稿2022/12/15 22:39

knuser

総合スコア178

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

michaelkami

2022/12/16 01:16

ありがとうございます! サンプル読み解いてみます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問