我正在尝试从csv文件中收集文本数据,并根据预定义的模式将其转换为可读的XML。我的问题似乎源于阅读和编写挪威特殊字符(ø,æ,å),而不了解如何正确使用unicode。
with open(inputfile, 'rb') as csvfile:
dialect = csv.Sniffer().sniff(csvfile.read(1024))
csvfile.seek(0)
reader = csv.reader(csvfile, dialect)
idflag=False
try:
for row in reader:
if idflag:
#print row[0]
toEBU(row,id_row)
#idflag=False #for testing, limits iterations
if row[0].lower()=='id':
idflag=True
id_row=row
这是用于读取.csv文件的代码。 toEbu函数处理XMl转换:
def toEBU(row,id_row):
file_id=unicode(row[0],"utf-8")
file_source=unicode(row[2],"utf-8")
file_type=unicode(row[3],"utf-8")
file_name=unicode(row[4],"utf-8")
file_desc=unicode(row[5],"utf-8")
file_keys=unicode(row[9],"utf-8")
file_rights=unicode(row[10],"utf-8")
keywords = file_keys.split(',')
#print row[0],row[4]
#Remember to use .strip() to remove spaces before or after string
if file_name=='' or row[1]=='Nei':
print 'Name Error'
return
tree = ET.parse('EBUBase.xml')
EBUMain = tree.getroot()
EBUMain.tag= 'ebucore:ebuCoreMain'
coreMetaData = ET.Element('ebucore:coreMetaData')
EBUMain.append(coreMetaData)
indent(EBUMain)
tree = ET.ElementTree(EBUMain)
xmlfile='xml\\' +file_id.strip()+'.xml'
#xmlfile=xmlfile.encode('utf-8')
print xmlfile
try:
tree.write(xmlfile, xml_declaration=True, encoding='utf-8', method="xml")
except IOError:
print 'Invalid Filename'
我得到的错误如下:
Traceback (most recent call last):
File "extractor.py", line 121, in <module>
main(sys.argv[1:])
File "extractor.py", line 106, in main
toEBU(row,id_row)
File "extractor.py", line 26, in toEBU
file_name=unicode(row[4],"utf-8")
UnicodeDecodeError: 'utf8' codec can't decode byte 0xe5 in position 9: invalid c
ontinuation byte
行[4]中的字符串是“BrylluppåTerningen”。
我尝试使用unicode csv解析器读取数据,但这似乎也会产生错误。所以我在写入XML之前尝试将字符转换为unicode。以前,我在编写相同的字符串时遇到问题,而代码在tree.write(XX)部分会失败。
编辑: 添加了csv文件中的示例:
18.6.,,Leveranse,Ferdig redigert 30 min AV presentason,Visning,Formidling,Digital historie,Ingen planer,,,
,,Kontaktperson,Tittel,E-post,Telefon,,,,,
,,XXXX XXXXX XXXXX,XXXXXXXXXXX,XXXX@XXXXXX.XXXX.XXXX,XXXXXXXX,,,,,
,,,,,,,,,,
Id,Arkiv,Kilde,Modalitet,"Parametre, Filnavn","Beskrivelse, fri tekst",Script,Dreiebok,Opptaksplan,Nøkkelord,Rettigheter
D5.1,Nei,E,Tekst,,Manus til videoforelesning (inneholder deler og bilder som beskrives under),Historisk oversikt over fyr og fyrliv i Frøya og Hitra,,Etter avtale med MMS,"Fyr, fyrstasjon",
D5.2,Ja,E,Video,25 minutter??,Film fyrvokter,Inspeksjonstur på Slettringen,,Opptak gjort av «Frøya Film og bilde» v Petter Vågsvær 2011,Fyrvokter slettringen,??
D5.3,Ja,E,Tekst,Fyr i krig,Digital fortelling,"Krigshistorie på fyr, med fokus på fyr i Trlag",,,"Krig, luftangrep, terningen",
第一行被忽略,只有以“D5.X”开头的行被发送到“toEBU”。
答案 0 :(得分:3)
要将其煮沸,您的文件很可能以'iso8859-1'编码。我可以用:
创建一个(较小的)文件版本from codecs import EncodedFile
with EncodedFile(open('n.txt','wb'),'utf-8','iso8859-1') as f:
f.write('Bryllup på Terningen')
EncodedFile的参数表示原始(在python中)是'utf-8',文件用'iso8859-1'编码。现在,如果我使用'iso8859-1'读取文件,我很好,但'utf-8'会出错:
>>> unicode(open('n.txt','rb').read(),'iso8859-1')
u'Bryllup p\xe5 Terningen'
>>> unicode(open('n.txt','rb').read(),'utf-8')
---------------------------------------------------------------------------
UnicodeDecodeError Traceback (most recent call last)
<ipython-input-8-2649b633aa10> in <module>()
----> 1 unicode(open('n.txt','rb').read(),'utf-8')
UnicodeDecodeError: 'utf8' codec can't decode byte 0xe5 in position 9: invalid continuation byte