2

XML::Twigを使用して、ゼロから新しい XML ドキュメントを作成しています。ルート要素には、プレフィックスと名前空間宣言が必要です。すべての子もこの名前空間に属し、このプレフィックスを使用する必要があります。

出力は次のようになります。

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<abc:root xmlns:abc="http://www.somehost.com/abc-data/ns/5.0.0" version="5.0.0.0">
 <abc:element name="myElement">
  This is my element
 </abc:element> 
</abc:root>

私はそれが次のように見えると思います:

my $new_twig = XML::Twig->new(map_xmlns => {'http://www.somehost.com/abc-data/ns/5.0.0' => "abc"}, pretty_print => 'indented');

my $root = XML::Twig::Elt->new('root');
$new_twig->set_encoding('UTF-8');
$new_twig->set_standalone("no");
$new_twig->set_root( $root);

my $element = XML::Twig::Elt->new('element' => {'name'=>'myElement};
$element->set_text('This is my element');
$element->paste(last_child=>$root);

# print in a file
open (TMP, "> $new_file_name");   
select TMP;
$new_twig->print(\*TMP);
close TMP;

これは簡単に思えるかもしれませんが、私はまだ Perl に慣れていないので、苦労しています。ご協力いただきありがとうございます!!!

4

1 に答える 1

4

このXML::Twigモジュールは、新しいデータをゼロから構築するのではなく、既存の XML を処理するためのものです。新しい XML ドキュメントを作成するために必要なのはクラスだけです。XML::Twig::EltメインXML::Twigクラスは関係ありません。

XML ドキュメントを作成するには、さまざまな方法があります。例として示した XML を作成する例を次に示します。

use strict;
use warnings;

use XML::Twig;

my $new_file_name = 'new.xml';

my $root = XML::Twig::Elt->new('abc:root', {
  'xmlns:abc' => "http://www.somehost.com/abc-data/ns/5.0.0",
  version => "5.0.0.0",
});
$root->insert_new_elt('abc:element' => {name => 'myElement'}, 'This is my element');
$root->set_pretty_print('indented');
$root->print_to_file($new_file_name);

出力

<abc:root version="5.0.0.0" xmlns:abc="http://www.somehost.com/abc-data/ns/5.0.0">
  <abc:element name="myElement">This is my element</abc:element>
</abc:root>

アップデート

の最新バージョンへのアップグレードが難しい場合は、への呼び出しをにXML::Twig置き換えることで同等の効果を得ることができますprint_to_file

open my $out, '>:utf8', $new_file_name or die qq(Cannot create "$filename": $!);
$root->print($out);
于 2012-03-27T09:57:31.083 に答える