我正在尝试从CSV文件创建一个词云。作为示例,CSV文件的结构如下:
它有更多的行,大约1800行左右。第一列是字符串值(名称),第二列是它们对应的频率(整数)。然后,文件被读取,并且键值对行被存储在一个字典(d)中,因为我们稍后将使用它来绘制词云图。
一旦我们有了充满值的字典,我尝试绘制词云图:
最后,文档中写道:
所以,我不明白为什么在满足函数要求的情况下会出现这个错误。希望有人能帮助我,谢谢。
注意:
我使用的是worldcloud 1.3.1版本。
a,1
b,2
c,4
j,20
它有更多的行,大约1800行左右。第一列是字符串值(名称),第二列是它们对应的频率(整数)。然后,文件被读取,并且键值对行被存储在一个字典(d)中,因为我们稍后将使用它来绘制词云图。
reader = csv.reader(open('namesDFtoCSV', 'r',newline='\n'))
d = {}
for k,v in reader:
d[k] = v
一旦我们有了充满值的字典,我尝试绘制词云图:
#Generating wordcloud. Relative scaling value is to adjust the importance of a frequency word.
#See documentation: https://github.com/amueller/word_cloud/blob/master/wordcloud/wordcloud.py
wordcloud = WordCloud(width=900,height=500, max_words=1628,relative_scaling=1,normalize_plurals=False).generate_from_frequencies(d)
plt.imshow(wordcloud, interpolation='bilinear')
plt.axis("off")
plt.show()
But an error is thrown:
Traceback (most recent call last):
File ".........../script.py", line 19, in <module>
wordcloud = WordCloud(width=900,height=500, max_words=1628,relative_scaling=1,normalize_plurals=False).generate_from_frequencies(d)
File "/usr/local/lib/python3.5/dist-packages/wordcloud/wordcloud.py", line 360, in generate_from_frequencies
for word, freq in frequencies]
File "/usr/local/lib/python3.5/dist-packages/wordcloud/wordcloud.py", line 360, in <listcomp>
for word, freq in frequencies]
TypeError: unsupported operand type(s) for /: 'str' and 'float
最后,文档中写道:
def generate_from_frequencies(self, frequencies, max_font_size=None):
"""Create a word_cloud from words and frequencies.
Parameters
----------
frequencies : dict from string to float
A contains words and associated frequency.
max_font_size : int
Use this font-size instead of self.max_font_size
Returns
-------
self
所以,我不明白为什么在满足函数要求的情况下会出现这个错误。希望有人能帮助我,谢谢。
注意:
我使用的是worldcloud 1.3.1版本。