如何使用pyspark统计词频?
使用spark统计词频
from pyspark import SparkContext
sc = SparkContext('local', "WordCount")
data=["mixlab", "mixlab 无界 社区","mixlab 让 每个人 无限 可能 跨界 设计师 全栈 程序员 算法 工程师","shadow","hello shadow"]
lines = sc.parallelize(data)
result = lines.flatMap(lambda x: x.split(" ")).countByValue()
for key, value in result.items():
print("%s %i" % (key, value))
处理结果
mixlab 3
无界 1
社区 1
让 1
每个人 1
无限 1
可能 1
跨界 1
设计师 1
全栈 1
程序员 1
算法 1
工程师 1
shadow 2
hello 1
x = sc.parallelize([1,2,3])
y = x.flatMap(lambda x: (x+1,300*x,x/2))
print(x.collect())
print(y.collect())
#[1, 2, 3]
#[2, 300, 0.5, 3, 600, 1.0, 4, 900, 1.5]
"AB"
,"B"
,"B"
])y = x.countByValue()
print(x.collect())
print(y)
#['AB', 'B', 'B']
#{'AB': 1, 'B': 2}
统计一个RDD中各个value的出现次数。返回一个map,map的key是元素的值,value是出现的次数。
统计词频的技能你get了吗?可以加入mixlab无界社区交流~
赞 (0)