4.RDD操作_rd命令的用法

4.RDD操作_rd命令的用法一、 RDD创建 从本地文件系统中加载数据创建RDD sc:SparkContext(shell自动创建) 本地文件系统中加载数据创建RDD Spark采用textFile()方法来从文件系统中加载数

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自动创建)

    4.RDD操作_rd命令的用法

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

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

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

    • 本地文件系统的地址

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

    • 或者是Amazon S3的地址等等

    4.RDD操作_rd命令的用法

从HDFS加载数据创建RDD

  1. 启动hdfs

    4.RDD操作_rd命令的用法

  2. 上传文件

    4.RDD操作_rd命令的用法

  3. 查看文件

    4.RDD操作_rd命令的用法

    4.RDD操作_rd命令的用法

  4. spark内加载文件

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

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

    4.RDD操作_rd命令的用法

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

    4.RDD操作_rd命令的用法

    4.RDD操作_rd命令的用法

  5. 停止hdfs

    4.RDD操作_rd命令的用法

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

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

    4.RDD操作_rd命令的用法

二、 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)

  • 显式定义函数

    4.RDD操作_rd命令的用法

    结果不明显,换个关键词

    4.RDD操作_rd命令的用法

  • lambda函数

    4.RDD操作_rd命令的用法

map(func)

  1. 字符串分词

    • 显式定义函数

      4.RDD操作_rd命令的用法

    • lambda函数

      4.RDD操作_rd命令的用法

  2. 数字加100

    • 显式定义函数

      4.RDD操作_rd命令的用法

    • lambda函数

      4.RDD操作_rd命令的用法

  3. 字符串加固定前缀

    • 显式定义函数

      4.RDD操作_rd命令的用法

    • lambda函数

      4.RDD操作_rd命令的用法

flatMap(func)

  1. 分词

    4.RDD操作_rd命令的用法

  2. 单词映射成键值对

    4.RDD操作_rd命令的用法

reduceByKey()

  1. 统计词频,累加

    4.RDD操作_rd命令的用法

  2. 乘法规则

    4.RDD操作_rd命令的用法

groupByKey()

  1. 单词分组

    4.RDD操作_rd命令的用法

  2. 查看分组的内容

    4.RDD操作_rd命令的用法

  3. 分组之后做累加 map

    4.RDD操作_rd命令的用法

sortByKey()

  1. 词频统计按单词排序

    4.RDD操作_rd命令的用法

sortBy()

  1. 词频统计按词频排序

    4.RDD操作_rd命令的用法

行动操作

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

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

foreach(func)

  • foreach(print)

    4.RDD操作_rd命令的用法

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

    4.RDD操作_rd命令的用法

collect()

4.RDD操作_rd命令的用法

count()

4.RDD操作_rd命令的用法

take(n)

4.RDD操作_rd命令的用法

reduce()

  • 数值型的rdd元素做累加

    4.RDD操作_rd命令的用法

  • 与reduceByKey区别

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/5402.html

(0)
上一篇 2023-05-10
下一篇 2023-05-11

相关推荐

  • Oracle学习笔记十九:PL/SQL流程控制语句

    Oracle学习笔记十九:PL/SQL流程控制语句一、引言 • PL/SQL 程序可通过条件或循环结构来控制命令执行的流程。 • PL/SQL 提供了丰富的流程控制语句,与 Java 一样也有三种控制结构: • 顺序结构 • 选择结构 • 循环结构

    2023-05-20
    105
  • 解决PS闪退问题

    解决PS闪退问题Photoshop(简称PS)是一款功能强大的图像编辑软件,它被广泛应用于广告、摄影和设计等领域。但是,有时候我们可能会遇到PS闪退的问题,这会影响到我们的工作效率。本文将从多个方面探讨PS闪退问题的原因及解决方法。

    2024-05-07
    12
  • 利用Python和Matlab逐行读取文件

    利用Python和Matlab逐行读取文件Python中,我们可以使用open()函数来打开文件。默认情况下,它会以只读模式打开文件,并返回一个文件对象。

    2023-12-18
    60
  • 学习之Redis(一)「建议收藏」

    学习之Redis(一)「建议收藏」一、redis简介 一般学习,最好先去官网,之所以建议看官网,是因为这是一手的学习资料,其他资料都最多只能算二手,一手资料意味着最权威,准确性最高。https://redis.io/topics/in

    2022-12-26
    95
  • mysql将字符串转成数字

    mysql将字符串转成数字//需要先转换成数字再进行排序 1.直接用加法 字符串+0 eg: select * from orders order by (mark+0) desc 2.使用函数 CAST(value as …

    2023-03-29
    110
  • 数据大屏设计工具_led大屏搭建教程

    数据大屏设计工具_led大屏搭建教程基于可视化搭建的方式来实现通用数据大屏搭建的解决方案,通过对平台能力的开发来讲解可视化搭建的核心功能实现,帮助有需要的同学了解可视化搭建的整体架构设计流程。

    2023-06-11
    100
  • 京东张政:内容理解在广告场景下的实践和探索[通俗易懂]

    京东张政:内容理解在广告场景下的实践和探索[通俗易懂]分享嘉宾:张政 京东 算法工程师 编辑整理:AMS 周金星 出品平台:DataFunTalk 导读: 内容生态建设是近几年互联网快速发展的关键动因,也是AI化的重点方向之一。本文主要分享在京东广告业务

    2023-05-23
    98
  • 精准计时,精密控制:Python秒级计时器

    精准计时,精密控制:Python秒级计时器计时器是指能够精准计算时间间隔、实现定时操作的一种工具。在很多项目的开发中,我们需要调用定时器来实现某些功能,如协助完成数据传输与同步、对网络连接进行监控、进行数据备份或者是在游戏场景中进行动画效果等。Python是一种非常强大的脚本语言,它拥有灵活的语法、支持大多数平台和操作系统,使用Python编写计时器也是非常便捷的。

    2024-03-25
    33

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注