linux的xml文件格式,linux – 如何将非UTF-8格式的xml文件转换为符合UTF-8的xml
我有一個巨大的xml文件,其示例數據如下:
因為可以看到有文字“Gesellschaftf??rBildverarbeitung”,它不符合UTF-8,因為我從xml驗證器得到錯誤,錯誤如:
Import failed:
com.sun.org.apache.xerces.internal.impl.io.MalformedByteSequenceException: Invalid byte 1 of 1-byte UTF-8 sequence.
那么查詢是如何在Linux環境中處理這個問題,將xml文件轉換為UTF-8兼容格式?或者在bash中是否存在這樣的方式,以便在首先創建xml時,我可以確保所有變量/字符串都以UTF-8兼容格式存儲?
解決方法:
使用字符集轉換工具:
iconv -f ISO-8859-1 -t UTF-8 filename.txt
00-0B-91 (hex) Aglaia Gesellschaft für Bildverarbeitung und Kommunikation m
000B91 (base 16) Aglaia Gesellschaft für Bildverarbeitung und Kommunikation m
Tiniusstr. 12-15
Berlin D-13089
GERMANY
似乎“ü”是獲得mangeld的角色.
更新
當使用wget下載“oui.txt”時,我在文件中看到字符“ü”.如果您沒有在下載中破壞某些內容.考慮使用以下其中一種:
> wget –header =’Accept-Charset:utf-8′
>嘗試使用curl -o oui.txt代替
如果以上都不起作用,只需在您喜歡的瀏覽器中打開鏈接并執行“另存為”.在這種情況下,請在下面的腳本中注釋wget行.
我成功使用以下腳本(更新BEGIN& END以獲取有效的XML文件)
#!/bin/bash
wget http://standards.ieee.org/develop/regauth/oui/oui.txt
iconv -f iso-8859-15 -t utf-8 oui.txt > converted
awk 'BEGIN {
print "HTML-header"
}
/base 16/ {
printf("\n", $4)
read
desc = substr($0, index($0, $4))
printf("\n", $1, desc)
}
END {
print "HTML-footer"
}
' converted
希望這可以幫助!
標簽:shell,unix,linux,unicode,utf-8
來源: https://codeday.me/bug/20190630/1338523.html
總結
以上是生活随笔為你收集整理的linux的xml文件格式,linux – 如何将非UTF-8格式的xml文件转换为符合UTF-8的xml的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 网络通端口映射工具
- 下一篇: Summary for linux