使用 python 2.7 我正在使用这些文件http://www.2shared.com/file/biSx7NI-/comer.html进行 os.walk,然后将结果与数组进行比较。在实际程序中,该数组不会被预定义。我尝试使用的代码如下
# -*- coding: utf-8 -*-
import os.path
group = ['comer.txt', 'coma.txt', 'comamos.txt', 'coman.txt', 'comas.txt', 'come.txt', 'comed.txt', 'comemos.txt', 'comen.txt', 'comeremos.txt', 'comer\xc3\xa1.txt', 'comer\xc3\xa1n.txt', 'comer\xc3\xa1s.txt', 'comer\xc3\xa9.txt', 'comer\xc3\xa9is.txt', 'comer\xc3\xada.txt', 'comer\xc3\xadais.txt', 'comer\xc3\xadamos.txt', 'comer\xc3\xadan.txt', 'comer\xc3\xadas.txt', 'comes.txt', 'comido.txt', 'comiendo.txt', 'comiera.txt', 'comierais.txt', 'comieran.txt', 'comieras.txt', 'comiere.txt', 'comiereis.txt', 'comieren.txt', 'comieres.txt', 'comieron.txt', 'comimos.txt', 'comiste.txt', 'comisteis.txt', 'comi\xc3\xa9ramos.txt', 'comi\xc3\xa9remos.txt', 'comi\xc3\xb3.txt', 'como.txt', 'com\xc3\xa1is.txt', 'com\xc3\xa9is.txt', 'com\xc3\xad.txt', 'com\xc3\xada.txt', 'com\xc3\xadais.txt', 'com\xc3\xadamos.txt', 'com\xc3\xadan.txt', 'com\xc3\xadas.txt', 'comer\xc3\xa1.txt', 'comer\xc3\xa9.txt', 'comer\xc3\xada.txt', 'comer\xc3\xadais.txt']
print "********what we have*********"
i=0
for f in group:
group[i] = os.path.basename(f)
group[i] = unicode(group[i], "utf-8")
print group[i]
i += 1
wantedResults = []
print "********what we want*********"
for(path, dirs, files) in os.walk("C:\corpus\zz-auto generated\spanish\comer"):
wantedResults.append(files)
for f in wantedResults[0]:
print f
print "********problems*********"
for resultWanted in wantedResults[0]:
if resultWanted not in group:
print "did not match our wanted results: " + resultWanted
for result in group:
if result not in wantedResults[0]:
print "extra file: " + result
我收到此错误:
警告(来自警告模块):文件“C:\Users***\Desktop\osWalkTest.py”,如果结果不在 WantResults[0] 中,则第 26 行:UnicodeWarning:Unicode 相等比较未能将两个参数都转换为 Unicode ->解释他们是不平等的
我真的可以使用一些帮助来获取预定义数组和从 os.walk 正确比较的数组。我在谷歌上查过这个,并尝试了许多编码和解码这两个数组的组合,但似乎没有任何效果。谢谢。