Spark的RDD编程(二)公众号undefined110
创建RDD有两种方式:①读取外部数据集,lines=sc.textFile("README.md")。②对一个集合进行并行化,lines=sc.parallelize(["zhangsan","lisi"])。
2.从http://files.grouplens.org/datasets/movielens/ml-100k.zip下载分析数据。到其目录中查看有几个重要的文件u.user(用户属性文件),u.item(电影元数据),u.data(用户对电影的评级)
3.启动pyspark,加载ml-100k文件中的数据,user_data=sc.textFile("/home/hadoop/ml-100k/u.user"),取其第一行数据检验是否加载成功user_data.first()。这是看见中间有大量日志。。严重干扰我们,这里可以设置日志,降低日志级别,只展示警告和错误。
4.分析数据,都是用"|"分割各行的数据,这将生成一个RDD,其中每一个记录对应一个Python列表,各列表由如下几个属性构成用户ID(user ID),年龄(age),性别(gender),职业(occupation)和邮编(ZIP code).对它们进行统计。。
>>> user_fields=user_data.map(lambda line:line.split("|"))
>>> num_users=user_fields.map(lambda fields:fields[0]).count()
>>> num_genders=user_fields.map(lambda fields:fields[2]).distinct().count()
>>> num_occupations=user_fields.map(lambda fields:fields[3]).distinct().count()
>>> num_ZIPcodes=user_fields.map(lambda fields:fields[4]).distinct().count()
>>> print"Users:%d,genders:%d,occ:%d,zipcodes:%d"%(num_users,num_genders,num_occupations,num_ZIPcodes)
输出结果:Users:943,genders:2,occ:21,zipcodes:795
5.接着用matplotlib的hist函数来创建一个直方图,以分析用户年龄的分布情况:hist(ages,bins=20,color='lightblue',normed=True)通过条形图反映量化比。。
6.了解用户的职业分布,首先用mapreduce(感觉spark中的这个方法比hadoop中的方便很多,而且速度也快很多)方法来计算数据集中个职业的出现次数。然后用matplotlib里面的bar函数绘制一个不同的条形图。
>>> count_by_occupation=user_fileds.map(lambda fields:(fields[3],1)).reduceByKey(lambda x,y:x+y).collect()
>>> print(count_by_occupation)
[(u'administrator', 79), (u'writer', 45), (u'retired', 14), (u'student', 196), (u'doctor', 7), (u'entertainment', 18), (u'marketing', 26), (u'executive', 32), (u'none', 9), (u'scientist', 31), (u'educator', 95), (u'lawyer', 12), (u'healthcare', 16), (u'technician', 27), (u'librarian', 51), (u'programmer', 66), (u'artist', 28), (u'salesman', 12), (u'other', 105), (u'homemaker', 7), (u'engineer', 67)]
>>> x_axisl=numpy.array([c[0] for c in count_by_occupation])
>>> y_axisl=numpy.array([c[1] for c in count_by_occupation])
7.得到各职业所占数量的RDD后,转化两个数组才能用来做条形图,分别对应X和Y轴。collect()函数收集返回的数量并不排序。因此建连个numpy数组,之后调用argsort()函数进行升序,形成新的数组。
>>> x_axis=x_axisl[numpy.argsort(x_axisl)]
>>> y_axis=y_axisl[numpy.argsort(y_axisl)]
8.有了x,y轴线,然后进行图形美化
>>> pos=numpy.arange(len(x_axis))
>>> width=1.0
>>> import matplotlib.pyplot as plt
>>> ax=plt.axes()
>>> ax.set_xticks(pos+(width/2))
>>> ax.set_xticklabels(x_axis)
>>> plt.bar(pos,y_axis,width,color='lightblue')
<Container object of 21 artists>
>>> plt.xticks(rotation=30)
>>> fig=plt.gcf()
>>> fig.set_size_inches(16,10)
>>> plt.show()
Spark的RDD编程(二)公众号undefined110的更多相关文章
- [Spark] Spark的RDD编程
本篇博客中的操作都在 ./bin/pyspark 中执行. RDD,即弹性分布式数据集(Resilient Distributed Dataset),是Spark对数据的核心抽象.RDD是分布式元素的 ...
- 大数据学习之hadoop伪分布式集群安装(一)公众号undefined110
hadoop的基本概念: Hadoop是一个由Apache基金会所开发的分布式系统基础架构. 用户可以在不了解分布式底层细节的情况下,开发分布式程序.充分利用集群的威力进行高速运算和存储. Hadoo ...
- 【微信SEO】公众号也能做排名?
[写于2016年8月] 最近,微信团队发出一则公告,开放公众号运营者一年内更改公众号名一次,这对不少名字起的奇葩名字(包括dkplus)的公众号来说是一件好事. 为什么说是好事呢?公众号名字直接关联到 ...
- 微信公众号授权登录后报redirect_uri参数错误的问题
在进行微信公众号二次开发的时候,需要通过授权码模式来进行微信授权.比如,在进行登录的时候,用户点击了登录按钮,然后弹出一个授权框,用户点击同意后,就可以获取用户的OpenId等信息了.这篇文章主要 ...
- 【spark 深入学习 06】RDD编程之旅基础篇02-Spaek shell
--------------------- 本节内容: · Spark转换 RDD操作实例 · Spark行动 RDD操作实例 · 参考资料 --------------------- 关于学习编程方 ...
- spark实验(四)--RDD编程(1)
一.实验目的 (1)熟悉 Spark 的 RDD 基本操作及键值对操作: (2)熟悉使用 RDD 编程解决实际具体问题的方法. 二.实验平台 操作系统:centos6.4 Spark 版本:1.5.0 ...
- Spark RDD编程-大数据课设
目录 一.实验目的 二.实验平台 三.实验内容.要求 1.pyspark交互式编程 2.编写独立应用程序实现数据去重 3.编写独立应用程序实现求平均值问题 四.实验过程 (一)pyspark交互式编程 ...
- 用java开发微信公众号:公众号接入和access_token管理(二)
本文为原创,原始地址为http://www.cnblogs.com/fengzheng/p/5027630.html 上一篇说了微信开发的准备工作,准备工作完成之后,就要开始步入正题了.其实微信公众号 ...
- C#微信公众号开发系列教程二(新手接入指南)
http://www.cnblogs.com/zskbll/p/4093954.html 此系列前面已经更新了两篇博文了,都是微信开发的前期准备工作,现在切入正题,本篇讲解新手接入的步骤与方法,大神可 ...
随机推荐
- sonarQube 管理
sonarQube是一个管理代码质量的开放平台,它可以从七个维度检测和扫描代码质量 参考百度文库:http://wenku.baidu.com/view/cba28af9b90d6c85ed3ac67 ...
- js冲突怎么解决
a.最容易出现的就是js的命名冲突①.变量名冲突变量有全局变量和局部变量当全局变量变量和局部变量名称一致时,就会js冲突,由于变量传递数值或地址不同就会产生JavaScript错误,甚至死循环.②.方 ...
- memcached与redis 对比
一. 综述 读一个软件的源码,首先要弄懂软件是用作干什么的,那memcached和redis是干啥的?众所周知,数据一般会放在数据库中,但是查询数据会相对比较慢,特别是用户很多时,频繁的查询,需要耗费 ...
- jQuery自定义多选下拉框
项目中需要自定义一个下拉框多选插件,业务问题还是自己实现比较好 通过$.fn 向jQuery添加新的方法 下拉数据通过参数传递进去,通过调用该插件时接收,选择后的确定与取消事件采用事件传递方式 代码如 ...
- sql server 获取每一个类别中值最大的一条数据
/* 数据如下: name val memo a 2 a2(a的第二个值) a 1 a1--a的第一个值 a 3 a3:a的第三个值 b 1 b1--b的第一个值 b 3 b3:b的第三个值 b 2 ...
- 查询,创建,扩充表空间&&impdp--------表空间大全
周六晚上还在办公室导入数据. 按schemas导入成功的关键是:导入的环境和源数据环境里面的表空间大小,表空间名字,需要一模一样 (当然,表空间大小创建到和源数据环境里面ues_size大小就可以了) ...
- shuffle() 函数(转)
定义和用法 shuffle() 函数把数组中的元素按随机顺序重新排列. 若成功,则返回 TRUE,否则返回 FALSE. 注释:本函数为数组中的单元赋予新的键名.这将删除原有的键名而不仅是重新排序. ...
- PHP获取文件行数
原文出处 提供两种实现方法,但是第一种效率最好 第一种: <?php $file_path = 'test.txt'; //文件路径 此处找一个1094644行的TXT文件 test.txt $ ...
- UTF-8和GBK有什么区别?
字符均使用双字节来表示,只不过为区分中文,将其最高位都定成1. 至于UTF-8编码则是用以解决国际上字符的一种多字节编码,它对英文使用8位(即一个字节),中文使用24位(三个字节)来编码.对于英文字符 ...
- Ubuntu系统中安装RPM格式包的方法
Ubuntu的软件包格式为deb,而RPM格式的包则是Red Hat 相关系统所用的软件包.当我们看到一个想用的软件包时,如果他是RPM格式,而你的操作系统是Ubuntu,那岂不是很遗憾?其实,在Ub ...