我的编程空间,编程开发者的网络收藏夹
学习永远不晚

4.RDD操作

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

4.RDD操作

4.RDD操作

目录
  • 一、 RDD创建
    • 从本地文件系统中加载数据创建RDD
    • 从HDFS加载数据创建RDD
    • 通过并行集合(列表)创建RDD
  • 二、 RDD操作
    • 转换操作
      • filter(func)
      • map(func)
      • flatMap(func)
      • reduceByKey()
      • groupByKey()
      • sortByKey()
      • sortBy()
    • 行动操作
      • foreach(func)
      • collect()
      • count()
      • take(n)
      • reduce()

一、 RDD创建

从本地文件系统中加载数据创建RDD

  • sc:SparkContext(shell自动创建)

  • 本地文件系统中加载数据创建RDD

    Spark采用textFile()方法来从文件系统中加载数据创建RDD

    该方法把文件的URI作为参数,这个URI可以是:

    • 本地文件系统的地址

    • 或者是分布式文件系统HDFS的地址

    • 或者是Amazon S3的地址等等

从HDFS加载数据创建RDD

  1. 启动hdfs

  2. 上传文件

  3. 查看文件

  4. spark内加载文件

    textFile默认是读hdfs,所以hdfs可以省略。

    hdfs的默认目录,前三条语句是完全等价的,可以使用其中任意一种方式

    不是默认目录,要还上路径

  5. 停止hdfs

通过并行集合(列表)创建RDD

  • 输入列表、字符串、numpy生成数组

二、 RDD操作

转换操作

  • 对于RDD而言,每一次转换操作都会产生新的RDD,供给下一个“转换”使用

  • 转换得到的RDD是惰性求值的,也就是说,整个转换过程只是记录了转换的轨迹,并不会发生真正的计算,只有遇到行动操作时,才会发生真正的计算,开始从血缘关系源头开始,进行物理的转换操作

操作 含义
filter(func) 筛选出满足函数func的元素,并返回一个新的数据集
map(func) 将每个元素传递到函数func中,并将结果返回为一个新的数据集
flatMap(func) 与map()相似,但每个输入元素都可以映射到0或多个输出结果
groupByKey() 应用于(K,V)键值对的数据集时,返回一个新的(K, Iterable)形式的数据集
reduceByKey(func) 应用于(K,V)键值对的数据集时,返回一个新的(K, V)形式的数据集,其中每个值是将每个key传递到函数func中进行聚合后的结果

filter(func)

  • 显式定义函数

    结果不明显,换个关键词

  • lambda函数

map(func)

  1. 字符串分词

    • 显式定义函数

    • lambda函数

  2. 数字加100

    • 显式定义函数

    • lambda函数

  3. 字符串加固定前缀

    • 显式定义函数

    • lambda函数

flatMap(func)

  1. 分词

  2. 单词映射成键值对

reduceByKey()

  1. 统计词频,累加

  2. 乘法规则

groupByKey()

  1. 单词分组

  2. 查看分组的内容

  3. 分组之后做累加 map

sortByKey()

  1. 词频统计按单词排序

sortBy()

  1. 词频统计按词频排序

行动操作

行动操作是真正触发计算的地方。Spark程序执行到行动操作时,才会执行真正的计算,从文件中加载数据,完成一次又一次转换操作,最终,完成行动操作得到结果。

操作 含义
count() 返回数据集中的元素个数
collect() 以数组的形式返回数据集中的所有元素
first() 返回数据集中的第一个元素
take(n) 以数组的形式返回数据集中的前n个元素
foreach(func) 将数据集中的每个元素传递到函数func中运行
reduce(func) 通过函数func(输入两个参数并返回一个值)聚合数据集中的元素

foreach(func)

  • foreach(print)

  • foreach(lambda a:print(a.upper())

collect()

count()

take(n)

reduce()

  • 数值型的rdd元素做累加

  • 与reduceByKey区别

    reduceByKey(func)应用于(K,V)键值对的数据集时,返回一个新的(K, V)形式的数据集,其中的每个值是将每个key传递到函数func中进行聚合后得到的结果

原文地址:https://www.cnblogs.com/DingyLand/archive/2022/03/30/homework_04_.html

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

4.RDD操作

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

4.RDD操作

目录一、 RDD创建从本地文件系统中加载数据创建RDD从HDFS加载数据创建RDD通过并行集合(列表)创建RDD二、 RDD操作转换操作filter(func)map(func)flatMap(func)reduceByKey()groupByKey()sor
4.RDD操作
2017-07-29

RDD的详解、创建及其操作

RDD的详解RDD:弹性分布式数据集,是Spark中最基本的数据抽象,用来表示分布式集合,支持分布式操作!RDD的创建RDD中的数据可以来源于2个地方:本地集合或外部数据源RDD操作分类转换算子Mapimport org.apache.spark.rdd.RD
RDD的详解、创建及其操作
2020-12-27

如何将RDD或者MLLib矩阵进行转置操作

如何将RDD或者MLLib矩阵进行转置操作,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。如何将Spark Mllib的矩阵或者将一个RDD进行转置操作。Spar
2023-06-19

4.Python操作Redis:哈希(H

Redis 数据库hash数据类型是一个string类型的key和value的映射表,适用于存储对象。Redis 中每个 hash 可以存储 232 - 1 键值对(40多亿)。 Python的redis模块实现了Redis哈希(Hash
2023-01-31

Go操作ES-4(query查询)

在Go中操作Elasticsearch进行查询,需要使用Elasticsearch的官方Go客户端库。以下是一个简单的示例,演示如何使用Go发送查询请求到Elasticsearch并获取结果:```gopackage mainimport
2023-09-21

【Python实践-4】切片操作去除字符

1 #利用切片操作,实现一个trim()函数,去除字符串首尾的空格,注意不要调用str的strip()方法 2 def trim(s): 3 while s[0:1]==' ': 4 s=s[1:] 5 wh
2023-01-31

如何解析Fedora Core 4操作技术含量

这期内容当中小编将会给大家带来有关如何解析Fedora Core 4操作技术含量,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。由于本人思维固化,对新事物接受不足,所以在学习Fedora Core 4 总是
2023-06-16

通过90行代码学会HTML5 WebSQL的4种基本操作

Web SQL数据库API是一个独立的规范,在浏览器层面提供了本地对结构化数据的存储,已经被很多现代浏览器支持了。我们通过一个简单的例子来了解下如何使用Web SQL API在浏览器端创建数据库表并存储数据。<
2023-06-05

Python操作SQLLite(基本操作

SQLite 是一个软件库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是在世界上最广泛部署的 SQL 数据库引擎。SQLite 源代码不受版权限制。Python SQLITE数据库是一款非常小巧的嵌
2023-01-31

怎样操作C++操作符

本篇文章给大家分享的是有关怎样操作C++操作符,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。C++中指令系统的每一条指令都有一个C++操作符,它表示该指令应进行什么性质的操作,
2023-06-17

Android开发中4个常用的工具类【Toast、SharedPreferences、网络及屏幕操作】

本文实例讲述了Android开发中4个常用的工具类。分享给大家供大家参考,具体如下:1、土司工具类(Toast管理)/** * Toast统一管理类 * * @Project App_ZXing * @Package com.android
2023-05-30

python(实操4):录音文件的读取、

#!/usr/bin/python# encoding:utf-8# Filename : processAudio.py# author by :morespeech# python2.7# platform:visual studio
2023-01-31

Oracle学习(七) --- MyBatis操作、JDBC操作

1、MyBatis操作1.1、环境搭建步骤一:创建项目 test_oracle步骤二:修改pom.xml文件(MyBatis相关依赖、Oracle驱动、测试依赖) changgou3_parent_java78 com.cz
Oracle学习(七) --- MyBatis操作、JDBC操作
2017-02-22

文件操作的艺术:操作系统中的高效操作

掌握文件操作的技巧对于任何操作系统用户都是至关重要的。本文将深入探讨文件操作的艺术,揭示在各种操作系统中实现高效操作的实用技巧。
文件操作的艺术:操作系统中的高效操作
2024-02-29
2024-04-02

编程热搜

目录