练习:文本排序

练习:
        对文本的内容进行排序
        按照(1,2,3....)顺序排序

    分析:
        1.创建一个HashMap集合对象,可以:存储每行文本的序号(1,2,3,..);value:存储每行的文本
        2.创建字符缓冲输入流对象,构造方法中绑定字符输入流
        3.创建字符缓冲输出流对象,构造方法中绑定字符输出流
        4.使用字符缓冲输入流中的方法readline,逐行读取文本
        5.对读取到的文本进行切割,获取行中的序号和文本内容
        6.把切割好的序号和文本的内容存储到HashMap集合中(key序号是有序的,会自动排序1,2,3,4..)
        7.遍历HashMap集合,获取每一个键值对
        8.把每一个键值对,拼接为一个文本行
        9.把拼接好的文本,使用字符缓冲输出流中的方法write,写入到文件中
        10.释放资源


package com.itheima.demo01.BufferedStream;

import java.io.*;
import java.util.HashMap;

public class Demo05Test {
    public static void main(String[] args) throws IOException {
        //1.创建一个HashMap集合对象,可以:存储每行文本的序号(1,2,3,..);value:存储每行的文本
        HashMap<String,String> map = new HashMap<>();
        //2.创建字符缓冲输入流对象,构造方法中绑定字符输入流
        BufferedReader br = new BufferedReader(new FileReader("10_IO\\in.txt"));
        //3.创建字符缓冲输出流对象,构造方法中绑定字符输出流
        BufferedWriter bw = new BufferedWriter(new FileWriter("10_IO\\out.txt"));
        //4.使用字符缓冲输入流中的方法readline,逐行读取文本
        String line;
        while((line = br.readLine())!=null){
            //5.对读取到的文本进行切割,获取行中的序号和文本内容
            String[] arr = line.split("\\.");
            //6.把切割好的序号和文本的内容存储到HashMap集合中(key序号是有序的,会自动排序1,2,3,4..)
            map.put(arr[0],arr[1]);
        }

        //7.遍历HashMap集合,获取每一个键值对
        for(String key : map.keySet()){
            String value = map.get(key);
            //8.把每一个键值对,拼接为一个文本行
            line = key + "." + value;
            //9.把拼接好的文本,使用字符缓冲输出流中的方法write,写入到文件中
            bw.write(line);
            bw.newLine();//写换行
        }
        //10.释放资源
        bw.close();
        br.close();
    }
}

 

在 IntelliJ IDEA 中使用 Apache Spark 进行文本数据(包含数字)的排序练习,可以按照以下步骤操作: 1. **安装Spark依赖**: - 首先确保已安装了Scala和Apache Spark。如果没有,可以在IntelliJ IDEA 的构建工具中添加Spark的支持。 2. **创建项目**: - 在IDEA中,选择 "New" -> "Project" 或 "Create New Project",然后选择合适的Spark模板,比如 "Spark Scala" 或 "Spark Java"。 3. **设置环境变量**: - 确保项目的运行配置指向你的本地Spark安装路径,包括`SPARK_HOME`等必要的环境变量。 4. **创建数据源**: - 创建一个包含数字的文本文件(例如 `numbers.txt`),并在项目目录下放置。可以用文本编辑器添加一些数字行。 5. **编写Spark程序**: - 使用Scala或Java编写读取文本、解析数字并排序的Spark代码。这里是一个简单的示例(Scala): ```scala import org.apache.spark.sql.SparkSession object SortNumbers { def main(args: Array[String]): Unit = { val spark = SparkSession.builder.appName("Sort Text with Numbers") .master("local[*]") // 使用本地模式运行 .getOrCreate() val textFile = spark.read.text("numbers.txt") // 读取文本文件 val numbers = textFile.selectExpr("split(value, ' ') as numbers") // 分割每一行为数组 val parsedNumbersDF = numbers.map(_.getAs[Seq[String]](0).map(_.toInt)) // 转换为整数数组 val sortedNumbers = parsedNumbersDF.sort() // 对数字进行排序 sortedNumbers.show() // 显示排序后的结果 spark.stop() // 关闭Spark会话 } } ``` 6. **运行和查看结果**: - 在IDEA中,点击绿色的运行图标或者通过菜单 "Run" > "Run 'SortNumbers'" 来启动程序。控制台将显示排序后的数字列表。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值