2

以下にサンプルを示します。

  <time_report>

 <project_ID>4</project_ID>

 <project_status>close</project_status>

 <client_ID>6001</client_ID>

     <time_record>

            <project_start_time>15:02:33</project_start_time>

            <project_end_time>15:07:44</project_end_time>

            <project_total_time>PT00H05M11S</project_total_time>

     </time_record>

 <employee_ID>10001</employee_ID>

 <employee_name>Mary Beth</employee_name>

 <date_created>2009-08-25</date_created>

</time_report>

次に、次の形式になるように出力します。

project_id, project_status, client_id, project_start_time, project_end_time,  project_total_time, employee_ID, employee_name, date_created

4, close, 6001, 15:02:33, 15:07:44, PT00H05M11S, 10001, Mary Beth, 2009-08-25

私はこれを行うために xmllint を使用しようとしてきましたが、残念ながら何の進展もありませんでした。これは bash/shell 環境で行います。どんな助けでも大歓迎です、ありがとう!

また、xmlファイルをExcelで開いてcsvとして保存すると、正しい結果が得られることを忘れていました。Linuxでそれを行う方法を探しているだけです。

    project_ID,project_status,client_ID,project_start_time,project_end_time,project_total_time,employee_ID,employee_name,date_created
4,close,6001,15:02:33,15:07:44,PT00H05M11S,10001,Mary Beth,8/25/2009
5,open,6003,12:00:00,12:45:00,PT00H45M00S,10003,Michelle,9/11/2009
2,close,6002,10:00:00,10:30:00,PT00H30M00S,10002,Joe,8/25/2009
2,open,6004,12:00:00,3:27:05,PT03H23M05S,10004,Mike,8/13/2009
4

3 に答える 3

4

xmlstarlet は、XML のクエリや XSLT 変換を実行できる非常に強力なコマンド ライン ツールです。XSLT XML->CSV の例がいくつか出回っていますが、次のワンライナーで必要なものが得られます。

xmlstarlet sel -B -t -m "//time_reports/time_report" -n -m "*" -v . -o , input.xml

<time_report>唯一の問題は、ルート レベルのタグでラップする必要があることでした。<time_reports>

于 2012-11-09T23:40:17.007 に答える
3

XML を CSV に変換するには (xsltproc などを使用)、次のような XSL スタイルシートを使用できます。

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="2.0"
    xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:output method="text" />
    <xsl:template match="/">
        <xsl:for-each select="//time_report[position()=1]/*">
            <xsl:if test="not(position()=1)">
                <xsl:text>,</xsl:text>
            </xsl:if>
            <xsl:value-of select="name()" />
        </xsl:for-each>
        <xsl:text>&#13;</xsl:text>
        <xsl:for-each select="//time_report">
            <xsl:for-each select="./*">
                <xsl:if test="not(position()=1)">
                    <xsl:text>,</xsl:text>
                </xsl:if>
                <xsl:value-of select="normalize-space(.)" />
            </xsl:for-each>
            <xsl:text>&#13;</xsl:text>
        </xsl:for-each>
    </xsl:template>
</xsl:stylesheet>
于 2012-11-09T23:43:53.197 に答える
2

私のXidelを使用することもできます:(xmlに空のフィールドがないと仮定して)

 xidel /tmp/test.xml -e '//time_report/string-join(.//text()[normalize-space(.)], ", ")'

標準のXPath2では、さまざまなコマンドラインパラメータの名前を覚えておく必要はありません。

またはその仮定なしで:

 xidel /tmp/test.xml -e '//time_report/string-join(.//*[not(*)], ", ")'
于 2012-11-09T23:59:47.710 に答える