我工作在Reddit上爬行,并得到了以下错误。我是新来的这个问题,并寻求建议,以克服错误
import praw
import json
reddit = praw.Reddit(client_id= client_id, \
client_secret= client_secret, \
user_agent= user1, \
username= username, \
password= password)
def prawSubreddit(subName, lm):
print("Collecting from /r/{}...".format(subName))
subreddit = reddit.subreddit(subName)
submissions = subreddit.top(limit=lm)
redditData = []
for submission in submissions:
keys = ['Title', 'Txt', 'Author']
func = [submission.title, submission.selftext, submission.author]
redditData.append(dict(zip(keys,func)))
print("Finished Collecting.")
writeOutput("{}.txt".format(subName),redditData)
def writeOutput(fileName, data):
`outputFile = open(fileName, "w")
outputFile.write(json.dumps(data, sort_keys = True))
if __name__ == '__main__':
prawSubreddit('opiates', 5)
在这种特定的情况下,可以通过铸造submission.author
与str(submission.author)
字符串解决问题。该json
库不能序列化Redditor
对象(这是submission.author
是什么),但它可以序列化的字符串。
所以,用func = [submission.title, submission.selftext, submission.author]
更换func = [submission.title, submission.selftext, str(submission.author)]
。