lxml内で要素を指定すると、その要素をすべて読み込んで再作成しなくても、xml文書のどこかで要素全体を移動できますか?私の最も良い例は両親を変えることです。私は少しドキュメントの周りをうろついたが、多くの運がなかった。前もって感謝します!要素全体をlxml.etreeで移動する
7
A
答えて
14
.append
、.insert
およびその他の操作が持つノードを移動するときにデフォルトで
>>> from lxml import etree
>>> tree = etree.XML('<a><b><c/></b><d><e><f/></e></d></a>')
>>> node_b = tree.xpath('/a/b')[0]
>>> node_d = tree.xpath('/a/d')[0]
>>> node_d.append(node_b)
>>> etree.tostring(tree) # complete 'b'-branch is now under 'd', after 'e'
'<a><d><e><f/></e><b><c/></b></d></a>'
>>> node_f = tree.xpath('/a/d/e/f')[0] # Nothing stops us from moving it again
>>> node_f.append(node_a) # Now 'a' is deep under 'f'
>>> etree.tostring(tree)
'<a><d><e><f><b><c/></b></f></e></d></a>'
は注意してくださいことをやりますテールテキスト。 lxmlのテールテキストでは、ノードに属していて、それに沿って移動します。 (ノードを削除する場合も、その尾のテキストも削除されます)
>>> tree = etree.XML('<a><b><c/></b>TAIL<d><e><f/></e></d></a>')
>>> node_b = tree.xpath('/a/b')[0]
>>> node_d = tree.xpath('/a/d')[0]
>>> node_d.append(node_b)
>>> etree.tostring(tree)
'<a><d><e><f/></e><b><c/></b>TAIL</d></a>'
は、時にはそれは、所望の効果だが、時にはあなたはそのようなものが必要になります。私がまさに必要
>>> tree = etree.XML('<a><b><c/></b>TAIL<d><e><f/></e></d></a>')
>>> node_b = tree.xpath('/a/b')[0]
>>> node_d = tree.xpath('/a/d')[0]
>>> node_a = tree.xpath('/a')[0]
>>> # Manually move text
>>> node_a.text = node_b.tail
>>> node_b.tail = None
>>> node_d.append(node_b)
>>> etree.tostring(tree)
>>> # Now TAIL text stays within its old place
'<a>TAIL<d><e><f/></e><b><c/></b></d></a>'
0
既存の要素にサブ要素を追加する.append()
、.insert()
メソッドを使用することができます。
>>> from lxml import etree
>>> from_ = etree.fromstring("<from/>")
>>> to = etree.fromstring("<to/>")
>>> to.append(from_)
>>> etree.tostring(to)
'<to><from/></to>'
関連する問題
- 1. lxml.etree、element.textは要素からテキスト全体を返しません
- 2. ドメイン全体にユーザーオブジェクトを移動する
- 3. 最初まで移動せずに要素全体をヤンクすることは可能ですか?
- 4. div要素全体をxピクセル上に移動するにはどうすればよいですか?
- 5. CSS :: after要素を要素に移動
- 6. フォームラジオボタンをクリックすると、エッジがHTML要素全体を画面の左側に移動しますか?
- 7. 移動要素が
- 8. javascriptで移動する要素
- 9. Androidで画面全体に画像を移動する方法
- 10. Xna全体でモデルを移動するには?
- 11. Sortableリストは、Jqueryで各リスト要素の代わりにリスト全体を移動します
- 12. CodeIgniter - データベース要素を移動
- 13. ドロップダウンメニューの要素を移動
- 14. ObjectMapper条件付きマッピング全体要素
- 15. スクロールの要素を移動する
- 16. 配列の要素を移動する#
- 17. DOM要素を移動するメソッド
- 18. JS内の要素を移動する
- 19. br要素を移動する
- 20. イメージ要素をナビゲーションバー要素に移動する方法
- 21. ブロック要素内のインライン要素を移動する
- 22. サラウンド要素を拡大しないで要素を移動
- 23. ページ全体にランダムな量の画像を移動する
- 24. QML: "全体"ウィンドウのマウス移動イベントを監視する
- 25. バックグラウンド全体をマウスポインタの逆に移動する方法p5.js
- 26. ループ内でdom要素を移動
- 27. jqueryで要素を上下に移動
- 28. プロローグ:リスト間で要素を移動
- 29. CSS&HTML移動要素
- 30. 全要素を検索する要素
を。ありがとう! – Cryptite
Type-o ?: node_aはnode_f.append(node_a)行のnode_bでなければなりません# 'a'は 'f'の下にあります(コメント 'a'も修正します)。 –