利用MapReduce计算平均数
利用mapreduce求出股票价格的开盘和收盘平均数
下图为采集到的股票信息,共计1416支股票的信息
因为在linux系统下默认采用utf-8的编码格式,而在win下txt默认采用ANSI编码格式。所以需要在linux下将文件转换一下格式,可以采用:
- package economic;
- import java.io.IOException;
- import java.util.Iterator;
- import java.util.StringTokenizer;
- import org.apache.hadoop.conf.Configuration;
- import org.apache.hadoop.fs.Path;
- import org.apache.hadoop.io.FloatWritable;
- import org.apache.hadoop.io.IntWritable;
- import org.apache.hadoop.io.LongWritable;
- import org.apache.hadoop.io.Text;
- import org.apache.hadoop.mapreduce.Job;
- import org.apache.hadoop.mapreduce.Mapper;
- import org.apache.hadoop.mapreduce.Reducer;
- import org.apache.hadoop.mapreduce.lib.input.FileInputFormat;
- import org.apache.hadoop.mapreduce.lib.output.FileOutputFormat;
- import org.apache.hadoop.util.GenericOptionsParser;
- public class ScoreAvgTest {
- /**
- *
- * @author hadoop www.ysgj1688.com KEYIN:输入map的key值,为每行文本的开始位置子字节计算,(0,11...)
- * VALUEIN:输入map的value,为每行文本值 KEYOUT :输出的key值 VALUEOUT:输出的value值
- */
- public static class MapperClass extends Mapper<Object, Text, Text, Text> {
- private Text companyName = new Text();
- private Text open = new Text();
- private Text data=new Text();
- private int n = 0;
- @Override
- protected void map(Object key, Text value, Context context)
- throws IOException, InterruptedException {
- // TODO Auto-generated method stub
- System.out.println(this.n);
- n++;
- String lineText = value.toString();
- String[] args = lineText.split("\\s+");
- if (args.length == 4) {
- this.companyName.set(args[1]);
- }
- if (args.length == 7) {
- try {
- System.out.println("Bfter Reducer:" + companyName + ","
- + args[1]);
- data.set(args[1]+" "+args[4]);
- context.write(this.companyName, data);
- } catch (IOException e) {
- e.printStackTrace(www.vboyl130.cn);
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- }
- }
- /**
- *
- * @author hadoop KEYIN:输入的名字 VALUEIN:输入的分数 KEYOUT:输出的名字 VALUEOUT:统计输出的平均分
- */
- public static class ReducerClass extends Reducer<Text, Text, Text, Text> {
- private Text text = new Text();
- protected void reduce(Text companyName, Iterable<Text> kaipan,
- Context context) throws IOException, InterruptedException {
- // TODO Auto-generated method stub
- double sumOpen = 0.0;
- double sumClose = 0.0;
- int num = 0;
- Iterator<Text> $it = kaipan.iterator();
- while ($it.hasNext())www.vboyule.cn {
- String record = $it.next(www.baohuayule.net ).toString();
- String[] getData=record.split(" ");
- System.out.println(num);
- System.out.println("原始数据:" + record);
- num++;
- System.out.println("第" www.qinlinyule.cn + num + "次循环");
- sumOpen += (Double.valueOf(getData[0])*100);
- sumClose+=(Double.valueOf(getData[1])*100);
- }
- double openPrise = sumOpen / (100 * num);
- double closePrise = sumClose / (100 * num);
- System.out.println("openPrice1:" + openPrise);
- System.out.println("www.120xh.cn closePrice1:" + closePrise);
- openPrise = (double) Math.round(openPrise * 100) / 100;
- closePrise = (double) Math.round(closePrise * 100) / 100;
- System.out.println("sumOpen:" + sumOpen+" sumClose"+sumClose);
- System.out.println("openPrice2:" + openPrise);
- System.out.println("closePrice2:" + closePrise);
- String result ="开盘平均价:"+Double.toString(openPrise)+", 收盘平均价:"+Double.toString(closePrise);
- text.set(result);
- try {
- context.write(companyName, text);
- } catch (IOException e) {
- e.printStackTrace();
- } catch (InterruptedException e) {
- e.printStackTrace();
- }
- }
- }
- public static void main(String[] args) throws IOException,
- InterruptedException, www.255055.cn/ ClassNotFoundException {
- Configuration conf = new Configuration();
- conf.set("fs.default.name", "hdfs://localhost:9000");
- String[] otherArgs = new String[] { "export", "output" }; //export为文本输入路径,output为输出路径
- if (otherArgs.length < 2) {
- System.err.println("Usage:wordcount<in>[<in>...]<out>");
- System.exit(2);
- }
- Job job = Job.getInstance(conf, "arg");
- job.setJarByClass(ScoreAvgTest.class);
- job.setMapperClass(MapperClass.class);
- // job.setCombinerClass(ReducerClass.class);
- System.out.println("Mapper over");
- job.setReducerClass(ReducerClass.class);
- System.out.println("Reducer over");
- job.setOutputKeyClass(Text.class);
- job.setOutputValueClass(Text.class);
- FileInputFormat.addInputPath(job, new Path(otherArgs[0]));
- FileOutputFormat.setOutputPath(job, new Path(otherArgs[1]));
- System.exit(job.waitForCompletion(true) ? 0 : 1);
- }
- }
运行后生成的output文件夹中的文件
利用MapReduce计算平均数的更多相关文章
- Hadoop阅读笔记(二)——利用MapReduce求平均数和去重
前言:圣诞节来了,我怎么能虚度光阴呢?!依稀记得,那一年,大家互赠贺卡,短短几行字,字字融化在心里:那一年,大家在水果市场,寻找那些最能代表自己心意的苹果香蕉梨,摸着冰冷的水果外皮,内心早已滚烫.这一 ...
- MapReduce计算模型的优化
MapReduce 计算模型的优化涉及了方方面面的内容,但是主要集中在两个方面:一是计算性能方面的优化:二是I/O操作方面的优化.这其中,又包含六个方面的内容. 1.任务调度 任务调度是Hadoop中 ...
- (第4篇)hadoop之魂--mapreduce计算框架,让收集的数据产生价值
摘要: 通过前面的学习,大家已经了解了HDFS文件系统.有了数据,下一步就要分析计算这些数据,产生价值.接下来我们介绍Mapreduce计算框架,学习数据是怎样被利用的. 博主福利 给大家赠送一套ha ...
- Hadoop 中利用 mapreduce 读写 mysql 数据
Hadoop 中利用 mapreduce 读写 mysql 数据 有时候我们在项目中会遇到输入结果集很大,但是输出结果很小,比如一些 pv.uv 数据,然后为了实时查询的需求,或者一些 OLAP ...
- 使用mapreduce计算环比的实例
最近做了一个小的mapreduce程序,主要目的是计算环比值最高的前5名,本来打算使用spark计算,可是本人目前spark还只是简单看了下,因此就先改用mapreduce计算了,今天和大家分享下这个 ...
- 利用sklearn计算文本相似性
利用sklearn计算文本相似性,并将文本之间的相似度矩阵保存到文件当中.这里提取文本TF-IDF特征值进行文本的相似性计算. #!/usr/bin/python # -*- coding: utf- ...
- MapReduce计算模型
MapReduce计算模型 MapReduce两个重要角色:JobTracker和TaskTracker. MapReduce Job 每个任务初始化一个Job,没个Job划分为两个阶段:Map和 ...
- MapReduce——计算温度最大值 (基于全新2.2.0API)
MapReduce——计算温度最大值 (基于全新2.2.0API) deprecated: Job类的所有Constructors, 新的API用静态方法getInstance(conf)来去的Job ...
- hadoop笔记之MapReduce的应用案例(利用MapReduce进行排序)
MapReduce的应用案例(利用MapReduce进行排序) MapReduce的应用案例(利用MapReduce进行排序) 思路: Reduce之后直接进行结果合并 具体样例: 程序名:Sort. ...
随机推荐
- CocoaAsyncSocket使用
代理的.h文件 #import <Foundation/Foundation.h> #import "GCDAsyncSocket.h" typedef void(^S ...
- CentOS7密码忘记解决方法&&GRUB菜单加密
CentOS7的root密码忘记怎么办 注意:该方法只适用于Linux7版本,可以用cat /redhat-release 查看 这里这里只介绍一种方法 1.启动的时候,在启动界面,相应启动项,内核名 ...
- vue笔记v-if
如果ite.type=='培训',显示第一个img, 如果ite.type=='会议',显示第二个img
- php mysql find_in_set函数 检索单子段 逗号分隔序列
FIND_IN_SET($kwd,field) 例如在 表 AA中 numbers 字段 保存列数据 1,4,8,75,41,7 就可以使用 FIND_IN_SET(8,numbers) 查询记 ...
- python安装教程(面向对象的解释型计算机程序设计语言)
inux下默认自带的.包括mac,是python2.x 但咱们玩的最新的 python3.x 怎么办呢centos下安装方法: sudo yum install epel- sudo yum i ...
- 【yii】【php】自定义故障代码
实际状态码: 200 操作成功 406 账号密码错误 208 请勿重复操作 401 需登陆验证 405 不容许此方法 409 验证错误
- Spark调优之JVM调优
一.JVM调优 JVM: 老年代: 存放少量生命周期长的对象,如连接池 年轻代: Spark task执行算子函数自己创建的大量对象 JVM机制: 对象进入java虚拟机之后会放在eden区域和一个s ...
- <Docker学习>3. docker镜像命令使用
镜像提供容器运行时所需要的程序,资源.配置文件等,是一个特殊的文件系统.是容器运行的基础.镜像是多层文件系统组成的,是一个分层存储的架构,在镜像的构建中,会一层层的构建,每一层构建完成就不会发生改变, ...
- 如何删除hive表格的分区
今天的一个业务场景就是要把三年的数据从第一天不停的融合起来,每一天作为表格一个新的分区.由于空间有限,数据量很大,可能每天数据都是几十个G的大小.所以我需要做的一点就是在融合这一天之后,删除一天的分区 ...
- Gson转Map时,Int会变成double解决方法
package com.cdy.demo; import java.lang.reflect.Type; import java.util.HashMap; import java.util.Map; ...