-1

lxml と etree を使用して html ファイルを解析しています。コードは次のようになります。

def get_all_languages():
    allLanguages = "http://wold.livingsources.org/vocabulary"
    f = urllib.urlopen(allLanguages).read()
    #inFile = "imLog.xml" 
    #html = f.read()
    #f.close()
    #encoding = chardet.detect(f)['encoding']
    #f.decode(encoding, 'replace').encode('utf-8')
    html = etree.HTML(f)
    #result = etree.tostring(html, pretty_print=True, method="html")
    #print result #is of type string
    #print type(result)
    return html

それよりも、ウェブサイドからいくつかの情報を抽出して配列に保存しています。文字列を配列に追加するときに、文字列のエンコードまたは形式が変更されます。ある種のユニコードオブジェクトかそうですか?? そのため、配列から削除して出力ファイルに出力するので、私にとっては難しいことではないと思いました。

def print_file():
#outputfile
output = 'WOLDDictionaries.txt'
dataLanguage = get_data_all_languages()
dataDictionaries = get_site_single_lang()
outputFile = open(output, "w")
outputFile.flush()
for index, array in enumerate(dataLanguage):
    indexLang = index 
    for item in array:  
        string = item
        #indexLang = index
        outputFile.write(string + "\t")
    outputFile.write("\n")
    #outputFile.flush()
    for index, array in enumerate(dataDictionaries):
        #stringArray = str(array)
        indexDic = index
        #outputFile.write(index + stringArray + "\t")
        if(indexLang == indexDic):
            #outputFile.write(string + "\t")
            for data in array:
            #stringData = str(data)
            #outputFile.write(stringData + "\t")
                for word in data:
                    stringWord = word
                    outputFile.write(stringWord + "\t")
                outputFile.write("\n")

    #outputFile.flush()

outputFile.close()  

うーん、この考えは間違っていました。ファイルに出力している間、エンコーディングはまだ間違っています。適切な文字を取得するにはどうすればよいですか?

4

1 に答える 1