如何解决AttributeError: 'list' 对象没有属性 'read_pickle'
这是我使用 pandas 的 read_pcikle 函数的代码。它可以用于单个文档。
import pandas as pd
tt = './data_v6/level3/6954/tweets_text_Kea.txt'
pd = pd.read_pickle(tt)
print(type(pd))
f = open("./data_v6/level3/6954/tweets_KeaWC.txt",'a',encoding='utf-8')
for i in pd:
#print(i)
#print(type(i))
for j in i:
res = isinstance(j,str)
if res == True:
print(j)
f.write(j+'\n')
然后我尝试在我的数据中的所有文件中使用这个函数。 但是我收到一个错误:AttributeError: 'list' object has no attribute 'read_pickle'。
import pandas as pd
import os
count = 1
for root,dirs,files in os.walk("./data_v6/level3/"):
for dir in dirs:
print(count)
#print(dir)
count += 1
tt = './data_v6/level3/'+dir+'/tweets_text_Kea.txt'
print(tt)
pd = pd.read_pickle(tt)
print(type(pd))
f = open("./data_v6/level3/"+dir+"/tweets_KeaWC.txt",encoding='utf-8')
for i in pd:
#print(i)
#print(type(i))
for j in i:
res = isinstance(j,str)
if res == True:
#print(j)
f.write(j+'\n')
解决方法
好吧,看看你在用熊猫做什么:
import pandas as pd # pd -> pandas
...
pd = pd.read_pickle(tt) # pd -> list
您不能将 read_pickle 分配给 pd;否则你不能再用 pd 调用 pandas 方法了!使用您的代码,您在重新分配 pd 之前调用了一次 pd,因此下次您调用 pd 时它不再起作用!
改用此代码:
import pandas as pd
import os
for root,dirs,files in os.walk("./data_v6/level3/"):
for dir in dirs:
tt = './data_v6/level3/'+dir+'/tweets_text_Kea.txt'
pickle_output = pd.read_pickle(tt)
f = open("./data_v6/level3/"+dir+"/tweets_KeaWC.txt",'a',encoding='utf-8')
for i in pickle_output:
for j in i:
res = isinstance(j,str)
if res == True:
f.write(j+'\n')
f.close()
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。