Perl初心者です。
下記のようなXMLファイル(test.xml)を、CSVに変換したいと考えています。
<MODESMESSAGE>
<DATETIME>20121129045500</DATETIME>
<MODES>8515C4</MODES>
<CALLSIGN>JAL1406</CALLSIGN>
<ALTITUDE>03075</ALTITUDE>
<GROUNDSPEED>177</GROUNDSPEED>
<TRACK>330</TRACK>
<VRATE>-832</VRATE>
<AIRSPEED>000</AIRSPEED>
<LATITUDE>35.4003</LATITUDE>
<LONGITUDE>139.8822</LONGITUDE>
<SQUAWK>3341</SQUAWK>
</MODESMESSAGE>
<MODESMESSAGE>
<DATETIME>20121129045500</DATETIME>
<MODES>86CF11</MODES>
<ALTITUDE>20100</ALTITUDE>
<VRATE>0</VRATE>
<AIRSPEED>000</AIRSPEED>
<LATITUDE>0</LATITUDE>
<LONGITUDE>0</LONGITUDE>
</MODESMESSAGE>
データによって、要素が欠けている場合もありますが、最大で11個の要素が並んでいます。
これをCSVに変換するため、書籍を参考にしながら以下のスクリプトxml2csv.plを作りました。
使用している環境はLinuxです。
use encoding "utf8", STDOUT=>"Shift_JIS";
use XML::Parser;
$parser = new XML::Parser( Handlers =>
{Start=>\&element_start,
Char => \&cdata,
End => \&element_end});
$element_name = '';
%records = {};
eval ( "\$parser->parsefile( \@ARGV[0] );");
if ($@) {
chomp($@);
$@ =~ s/^\n//;
$@ =~ s/ at (?:[A-Z]:)?\/.*//;
print @ARGV[0] . " :Error $@ \n";
}
sub element_start {
my ($expat, $name, %attributes) = @_;
$element_name = $name;
$records = {} if ( $name eq 'MODESMESSAGE' );
}
sub element_end {
my ($expat, $name) = @_;
if ( $name eq 'MODESMESSAGE' ) {
print $records{'DATETIME'} . "," . $records{'MODES'} . "," . $records{'CALLSIGN'} . "," . $records{'ALTITUDE'} . "," . $records{'GROUNDSPEED'} . "," . $records{'TRACK'} . "," . $records{'VRATE'} . "," . $records{'AIRSPEED'} . "," . $records{'LATITUDE'} . "," . $records{'LONGITUDE'} . "," . $records{'SQUAWK'} . "\n";
}
$element_name = '';
}
sub cdata {
my ($expat, $context) = @_;
$records{$element_name} = $context if ($element_name);
}
実行すると、
> perl xml2csv.pl test.xml
20121129045500,8515C4,JAL1406,03075,177,330,-832,000,35.4003,139.8822,3341
test.xml :Error junk after document element at line 14, column 0, byte 345
>
上記の通り1つ目のデータについてはCSVに変換できているようなのですが、2つ目以降が変換されずエラーとなってしまいます。
お気づきの点がありましたら教えていただけないでしょうか。
よろしくお願いします。
No.1ベストアンサー
- 回答日時:
test.xml の中身を
<XMLDOC>
<MODESMESSAGE>
...
<MODESMESSAGE>
<MODESMESSAGE>
...
<MODESMESSAGE>
...
</XMLDOC>
のようにタグで挟めば、よいと思う。 <XMLDOC> は単なる例で別に何でもよい。
よく知らないんだけど、挟まないとひとつの XML 文書にならないのじゃないかな ???
この回答への補足
t-okura 様
ご回答いただき、ありがとうございます。
test.xml の先頭・最後の行にそれぞれ以下の行を追加しました。
<XMLDOC>
...
</XMLDOC>
下記のように実行したところ、2つ目のデータについても変換できました。
ありがとうございます。
> perl xml2csv.pl test.xml
20121129045500,8515C4,JAL1406,03075,177,330,-832,000,35.4003,139.8822,3341
20121129045500,86CF11,JAL1406,20100,177,330,0,000,0,0,3341
上記の結果について重ねてお聞きしたいのですが、
test.xmlにおいて2つ目のデータでは、CALLSIGN、GROUNDSPEED、TRACK、SQUAWK等の要素がないため、
1つ目のデータの値がクリアされずにそのまま出力されてしまっています。
データがない場合は0または文字を消去して「,0,」または「,,」となるようにしたいのですが、
その場合どこを修正すればよろしいのでしょうか。
お手数をおかけします。
よろしくお願いします。
ありがとうございます。
各値をクリアすることで必要とする結果を得ることができました。
お手数をおかけしました。
おかげさまで助かりました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
テキストファイルで提出とは?
-
perlをバージョンアップしたら...
-
Strawberry Perl for Windows ...
-
Perlの全角スペース 文字化け?
-
Perlで、「が」を、「...
-
openした後、closeしないでプロ...
-
Perlでの文字列置換
-
Raspberry Pi
-
サクラエディターの設定の仕方...
-
Perl 特定のフォルダ以外削除
-
Perl 仮登録、本登録システムに...
-
Perl 正規表現
-
Perl テキスト 重複 個数
-
Perl言語について。
-
ファイルをディレクトリ分配の...
-
アルファベットに付いて質問し...
-
#!/usr/bin/perlで書きだしたCG...
-
Perlのエラーについてご教授く...
-
perlのflock関数でロックをかけ...
-
AI sisterとは、偽物の人ですか?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
順不同・任意のタグ
-
エクセルVBAのFunctionプロシー...
-
最低1つの要素が存在するグルー...
-
計算問題が分かりません… どな...
-
Eclipse でBASIC認証するには
-
PerlによるXMLからCSVへの変換...
-
PHPでXMLデータ生成、スキーマ...
-
XMLで主キーを自動的に入力する...
-
CPUの考え方を教えてください ...
-
東芝のDynabookなのですがアン...
-
XMLで要素が記述された順番に意...
-
SNMP リンクダウンとノードダ...
-
XML、XSLTの適応エラー(IEから...
-
ルート要素ノードが2個ある場合?
-
昔Winnyってありましたけど、あ...
-
バッチファイルでテキストファ...
-
C#でTreeViewのCheckBoxのサイ...
-
同じタグ名の項目取得
-
4バイトを10進数に変換する方法
-
Excel-VBAでXMLの複数ノードの...
おすすめ情報