我想尝试将一系列项目上传到test.wikidata,创建项目,然后添加一个初始P571声明。csv文件有时有日期值,有时没有。当没有给出日期值时,我想写出一个占位符‘一些值’。
想象一下这样的数据帧:
df = {'Object': [1, 2,3], 'Date': [250,,300]}但是,我不确定如何使用Pywikibot遍历csv文件,如何使用pywikibot为每行创建一个项并添加一条语句。下面是我写的代码:
import pywikibot
import pandas as pd
site = pywikibot.Site("test", "wikidata")
repo = site.data_repository()
df = pd.read_csv('experiment.csv')
item = pywikibot.ItemPage(repo)
for item in df:
date = df['date']
prop_date = pywikibot.Claim(repo, u'P571')
if date=='':
prop_date.setSnakType('somevalue')
else:
target = pywikibot.WbTime(year=date)
prop_date.setTarget(target)
item.addClaim(prop_date)当我通过PAWS运行这个命令时,我得到了这样的消息:KeyError: 'date'
但我认为这里真正的问题是,我不确定如何让Pywikibot迭代数据帧的每一行,并为每个新的日期值创建一个新的声明。对于好的例子和文档,我会重视任何反馈或建议。非常感谢!
发布于 2020-10-03 22:56:16
回过头来看,解决方案是使用.iterrows()或.itertuples()或.loc[]来访问行中的值。
所以
for item in df.itertuples():
prop_date = pywikibot.Claim(repo, u'P571')
if item.date=='':
prop_date.setSnakType('somevalue')
else:
target = pywikibot.WbTime(year=date)
prop_date.setTarget(target)
item.addClaim(prop_date)https://stackoverflow.com/questions/64108537
复制相似问题