问题
the problem is output result is not save in csv file. I'm using this code to weight-age the words positive and negative.I want to save in the csv file.Firstly, read the csv file ,apply tf-idf and output display on shell,but error disply when result write in csv file.
for i, blob in enumerate(bloblist):
    print("Top words in document {}".format(i + 1))
    scores = {word: tfidf(word, blob, bloblist) for word in blob.words}
    sorted_words = sorted(scores.items(), reverse=True)
    print(sorted_words)
    final = open("tfidf.csv", "w").write(sorted_words)
    print(final)
    print("done")
The error is:
   Top words in document 1
   Traceback (most recent call last):
   File "C:\Python34\webcrawler-Final.py", line 38, in <module>
   final = open("tfidf.csv", "w").write(sorted_words)
   TypeError: must be str, not list
回答1:
Try to this.
sorted_words = ''.join(sorted(scores.items(), reverse=True))
回答2:
As you dont specify in your post, I dont know which is the separator between values of the tuple, so I added a '\n'. You can change that to ' ' or whatever you want.
final = open("tfidf.csv", "w").write('\n'.join('%s, %s' % x for x in sorted_words))
来源:https://stackoverflow.com/questions/30612799/typeerror-must-be-str-not-list