ホームページ > バックエンド開発 > XML/RSS チュートリアル > lxmlがxmlを処理する際の文字エンコーディングの問題について詳しく解説

lxmlがxmlを処理する際の文字エンコーディングの問題について詳しく解説

黄舟
リリース: 2017-03-17 16:53:25
オリジナル
2507 人が閲覧しました

問題を単純化するために、xmlの内容は次の形式に簡略化されます:

<?xml version="1.0" encoding="gbk"?><DOCUMENT><da><![CDATA[中文,就是任性]]></da></DOCUMENT>
ログイン後にコピー

そのエンコーディングはgbkであり、ノードの1つは中国語の文字です
lxmlを使用して値を抽出するときに次の例外が発生しましたノードの

lxml.etree.XMLSyntaxError: Extra content at the end of the document
ログイン後にコピー

この時点で対応する Python スクリプトは次のとおりです:

tst = u'<?xml version="1.0" encoding="gbk"?><DOCUMENT><da><![CDATA[中文,就是任性]]></da></DOCUMENT>'
for event,element in etree.iterparse(BytesIO(tst.encode('utf-8'))):
    print("%s, %s" % (element.tag, element.text))
ログイン後にコピー

ただし、簡略化する前に別の例外が報告されました

lxml.etree.XMLSyntaxError: input conversion failed due to input error, bytes 0x8B 0x2C 0xE6 0x9D
ログイン後にコピー

どの例外であっても、やはりエンコーディングに関連していると推測されますキャラクターのフォルム。
さまざまな試みが役に立たなかった後、後でこの記事で言及されている問題が XML のエンコード値に関連していることを確認し、以前の Replace を置き換える置換ステートメントを追加してみました。エンコーディング = "gbk" とエンコーディング: "utf-8"

それで、最終的に結果が得られました:

tst = u'<?xml version="1.0" encoding="gbk"?><DOCUMENT><da><![CDATA[中文,就是任性]]></da></DOCUMENT>'
tst = tst.replace('encoding="gbk"', 'encoding="utf-8"')
for event,element in etree.iterparse(BytesIO(tst.encode('utf-8'))):
    print("%s, %s" % (element.tag, element.text))
ログイン後にコピー

以上がlxmlがxmlを処理する際の文字エンコーディングの問題について詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート