day21(IO(字符流)&字符流其他内容&递归)

###21.01_IO流(字符流FileReader)

* 1.字符流是什么

* 字符流是可以直接读写字符的IO流

* 字符流读取字符, 就要先读取到字节数据, 然后转为字符. 如果要写出字符, 需要把字符转为字节再写出.    

* 2.FileReader

* FileReader类的read()方法可以按照字符大小读取

*

FileReader fr = new FileReader("aaa.txt"); //创建输入流对象,关联aaa.txt

int ch;

while((ch = fr.read()) != -1) { //将读到的字符赋值给ch

System.out.println((char)ch); //将读到的字符强转后打印

}

 

fr.close(); //关流

 

###21.02_IO流(字符流FileWriter)

* FileWriter类的write()方法可以自动把字符转为字节写出

 

FileWriter fw = new FileWriter("aaa.txt");

fw.write("aaa");

fw.close();

 

###21.03_IO流(字符流的拷贝)

FileReader fr = new FileReader("a.txt");

FileWriter fw = new FileWriter("b.txt");

 

int ch;

while((ch = fr.read()) != -1) {

fw.write(ch);

}

 

fr.close();

fw.close();

###21.04_IO流(什么情况下使用字符流)

* 字符流也可以拷贝文本文件, 但不推荐使用. 因为读取时会把字节转为字符, 写出时还要把字符转回字节.

* 程序需要读取一段文本, 或者需要写出一段文本的时候可以使用字符流

* 读取的时候是按照字符的大小读取的,不会出现半个中文

* 写出的时候可以直接将字符串写出,不用转换为字节数组

 

###21.05_IO流(字符流是否可以拷贝非纯文本的文件)

* 不可以拷贝非纯文本的文件

* 因为在读的时候会将字节转换为字符,在转换过程中,可能找不到对应的字符,就会用?代替,写出的时候会将字符转换成字节写出去

* 如果是?,直接写出,这样写出之后的文件就乱了,看不了了  

 

###21.06_IO流(自定义字符数组的拷贝)

*

 

FileReader fr = new FileReader("aaa.txt"); //创建字符输入流,关联aaa.txt

FileWriter fw = new FileWriter("bbb.txt"); //创建字符输出流,关联bbb.txt

 

int len;

char[] arr = new char[1024*8]; //创建字符数组

while((len = fr.read(arr)) != -1) { //将数据读到字符数组中

fw.write(arr, 0, len); //从字符数组将数据写到文件上

}

 

fr.close(); //关流释放资源

fw.close();

 

###21.07_IO流(带缓冲的字符流)

* BufferedReader的read()方法读取字符时会一次读取若干字符到缓冲区, 然后逐个返回给程序, 降低读取文件的次数, 提高效率

* BufferedWriter的write()方法写出字符时会先写到缓冲区, 缓冲区写满时才会写到文件, 降低写文件的次数, 提高效率

*

BufferedReader br = new BufferedReader(new FileReader("aaa.txt")); //创建字符输入流对象,关联aaa.txt

BufferedWriter bw = new BufferedWriter(new FileWriter("bbb.txt")); //创建字符输出流对象,关联bbb.txt

 

int ch;

while((ch = br.read()) != -1) { //read一次,会先将缓冲区读满,从缓冲去中一个一个的返给临时变量ch

bw.write(ch); //write一次,是将数据装到字符数组,装满后再一起写出去

}

 

br.close(); //关流

bw.close();  

 

 

###21.08_IO流(readLine()和newLine()方法)

* BufferedReader的readLine()方法可以读取一行字符(不包含换行符号)

* BufferedWriter的newLine()可以输出一个跨平台的换行符号"\r\n"

*

BufferedReader br = new BufferedReader(new FileReader("aaa.txt"));

BufferedWriter bw = new BufferedWriter(new FileWriter("bbb.txt"));

String line;

while((line = br.readLine()) != null) {

bw.write(line);

//bw.write("\r\n"); //只支持windows系统

bw.newLine(); //跨平台的

}

 

br.close();

bw.close();

 

###21.09_IO流(将文本反转)

* 将一个文本文档上的文本反转,第一行和倒数第一行交换,第二行和倒数第二行交换

 

###21.10_IO流(LineNumberReader)

* LineNumberReader是BufferedReader的子类, 具有相同的功能, 并且可以统计行号

* 调用getLineNumber()方法可以获取当前行号

* 调用setLineNumber()方法可以设置当前行号

*

LineNumberReader lnr = new LineNumberReader(new FileReader("aaa.txt"));

String line;

lnr.setLineNumber(100); //设置行号

while((line = lnr.readLine()) != null) {

System.out.println(lnr.getLineNumber() + ":" + line);//获取行号

}

 

lnr.close();

 

###21.11_IO流(装饰设计模式)

 

*

interface Coder {

public void code();

}

 

class Student implements Coder {

 

@Override

public void code() {

System.out.println("javase");

System.out.println("javaweb");

}

 

}

 

class HeiMaStudent implements Coder {

private Student s; //获取到被包装的类的引用

public HeiMaStudent(Student s) { //通过构造函数创建对象的时候,传入被包装的对象

this.s = s;

}

@Override

public void code() { //对其原有功能进行升级

s.code();

System.out.println("数据库");

System.out.println("ssh");

System.out.println("安卓");

System.out.println(".....");

}

 

}

 

###21.12_IO流(使用指定的码表读写字符)

* FileReader是使用默认码表读取文件, 如果需要使用指定码表读取, 那么可以使用InputStreamReader(字节流,编码表)

* FileWriter是使用默认码表写出文件, 如果需要使用指定码表写出, 那么可以使用OutputStreamWriter(字节流,编码表)

*

BufferedReader br = //高效的用指定的编码表读

new BufferedReader(new InputStreamReader(new FileInputStream("UTF-8.txt"), "UTF-8"));

BufferedWriter bw = //高效的用指定的编码表写

new BufferedWriter(new OutputStreamWriter(new FileOutputStream("GBK.txt"), "GBK"));

int ch;

while((ch = br.read()) != -1) {

bw.write(ch);

}

 

br.close();

bw.close();

###21.13_IO流(转换流图解)

* 画图分析转换流

 

###21.14_IO流(获取文本上字符出现的次数)

* 获取一个文本上每个字符出现的次数,将结果写在times.txt上

分析:

     * 1,创建带缓冲的输入流对象

     * 2,创建双列集合对象TreeMap

     * 3,将读到的字符存储在双列集合中,存储的时候要做判断,如果不包含这个键,就将键和1存储,如果包含这个键,就将该键和值加1存储

     * 4,关闭输入流

     * 5,创建输出流对象

     * 6,遍历集合将集合中的内容写到times.txt中

     * 7,关闭输出流

   public static void main(String[] args) throws IOException {

        //1,创建带缓冲的输入流对象

        BufferedReader br = new BufferedReader(new FileReader("zzz.txt"));

        //2,创建双列集合对象TreeMap

        TreeMap<Character, Integer> tm = new TreeMap<>();

        //3,将读到的字符存储在双列集合中,存储的时候要做判断,如果不包含这个键,就将键和1存储,如果包含这个键,就将该键和值加1存储

        int ch;

        while((ch = br.read()) != -1) {

            char c = (char)ch;                  //强制类型转换

            /*if(!tm.containsKey(c)) {

                tm.put(c, 1);

            }else {

                tm.put(c, tm.get(c) + 1);

            }*/

            tm.put(c, !tm.containsKey(c) ? 1 : tm.get(c) + 1);

        }

        //4,关闭输入流

        br.close();

        //5,创建输出流对象

        BufferedWriter bw = new BufferedWriter(new FileWriter("times.txt"));

        //6,遍历集合将集合中的内容写到times.txt中

        for(Character key : tm.keySet()) {

            switch (key) {

            case '\t':

                bw.write("\\t" + "=" + tm.get(key));    

                break;

            case '\n':

                bw.write("\\n" + "=" + tm.get(key));

                break;

            case '\r':

                bw.write("\\r" + "=" + tm.get(key));

                break;

            default:

                bw.write(key + "=" + tm.get(key));          //写出键和值

                break;

            }

            bw.newLine();

        }

        //7,关闭输出流

        bw.close();

    }

 

}

###21.15_IO流(试用版软件)

* 当我们下载一个试用版软件,没有购买正版的时候,每执行一次就会提醒我们还有多少次使用机会用学过的IO流知识,模拟试用版软件,试用10次机会,执行一次就提示一次您还有几次机会,如果次数到了提示请购买正版

 

###21.16_File类(递归)

* 5的阶乘

* 递归:方法自己调用自己

     * 5!

     * 5 * 4 * 3 * 2 * 1

     *

     * 5 * fun(4)(代表4!)

     *      4 * fun(3)(代表3!)

     *              3 * fun(2)(代表2!)

     *                      2 * fun(1)(代表1!)

     * 递归的弊端:不能调用次数过多,容易导致栈内存溢出

     * 递归的好处:不用知道循环次数

     *

     * 构造方法是否可以递归调用?

     * 构造方法不能使用递归调用

     *

     * 递归调用是否必须有返回值?

     * 不一定(可以有,也可以没有)

public static void main(String[] args) {

        /*int result = 1;

 

        for(int i = 1; i <= 5; i++) {

            result = result * i;

        }

 

        System.out.println(result);*/

        System.out.println(fun(6000));

    }

 

    public static int fun(int num) {

        if(num == 1) {

            return 1;

        }else {

            return num * fun(num - 1);

        }

    }

}

###21.17_File类(练习)

* 需求:从键盘输入接收一个文件夹路径,打印出该文件夹下所有的.java文件名

分析:

     * 从键盘接收一个文件夹路径

     * 1,如果录入的是不存在,给与提示

     * 2,如果录入的是文件路径,给与提示

     * 3,如果是文件夹路径,直接返回

     *

     * 打印出该文件夹下所有的.java文件名

     * 1,获取到该文件夹路径下的所有的文件和文件夹,存储在File数组中

     * 2,遍历数组,对每一个文件或文件夹做判断

     * 3,如果是文件,并且后缀是.java的,就打印

     * 4,如果是文件夹,就递归调用

public static void main(String[] args) {

        File dir = getDir();

        printJavaFile(dir);

    }

 

    /*

     * 获取键盘录入的文件夹路径

     * 1,返回值类型File

     * 2,不需要有参数

     */

    public static File getDir() {

        Scanner sc = new Scanner(System.in);                //创建键盘录入对象

        System.out.println("请输入一个文件夹路径");

        while(true) {

            String line = sc.nextLine();                    //将键盘录入的文件夹路径存储

            File dir = new File(line);                      //封装成File对象

            if(!dir.exists()) {

                System.out.println("您录入的文件夹路径不存在,请重新录入");

            }else if(dir.isFile()) {

                System.out.println("您录入的是文件路径,请重新录入文件夹路径");

            }else {

                return dir;

            }

        }

    }

    /*

     * 获取文件夹路径下的所.java文件

     * 1,返回值类型 void

     * 2,参数列表File dir

     */

    public static void printJavaFile(File dir) {

        //1,获取到该文件夹路径下的所有的文件和文件夹,存储在File数组中

        File[] subFiles = dir.listFiles();

        //2,遍历数组,对每一个文件或文件夹做判断

        for (File subFile : subFiles) {

            //3,如果是文件,并且后缀是.java的,就打印

            if(subFile.isFile() && subFile.getName().endsWith(".java")) {

                System.out.println(subFile);

            //4,如果是文件夹,就递归调用

            }else if (subFile.isDirectory()){

                printJavaFile(subFile);

            }

        }

    }

}

###21.18_IO流(总结)

* 1.会用BufferedReader读取GBK码表和UTF-8码表的字符

* 2.会用BufferedWriter写出字符到GBK码表和UTF-8码表的文件中

* 3.会使用BufferedReader从键盘读取一行

 

在使用Python来安装geopandas包时,由于geopandas依赖于几个其他的Python库(如GDAL, Fiona, Pyproj, Shapely等),因此安装过程可能需要一些额外的步骤。以下是一个基本的安装指南,适用于大多数用户: 使用pip安装 确保Python和pip已安装: 首先,确保你的计算机上已安装了Python和pip。pip是Python的包管理工具,用于安装和管理Python包。 安装依赖库: 由于geopandas依赖于GDAL, Fiona, Pyproj, Shapely等库,你可能需要先安装这些库。通常,你可以通过pip直接安装这些库,但有时候可能需要从其他源下载预编译的二进制包(wheel文件),特别是GDAL和Fiona,因为它们可能包含一些系统级的依赖。 bash pip install GDAL Fiona Pyproj Shapely 注意:在某些系统上,直接使用pip安装GDAL和Fiona可能会遇到问题,因为它们需要编译一些C/C++代码。如果遇到问题,你可以考虑使用conda(一个Python包、依赖和环境管理器)来安装这些库,或者从Unofficial Windows Binaries for Python Extension Packages这样的网站下载预编译的wheel文件。 安装geopandas: 在安装了所有依赖库之后,你可以使用pip来安装geopandas。 bash pip install geopandas 使用conda安装 如果你正在使用conda作为你的Python包管理器,那么安装geopandas和它的依赖可能会更简单一些。 创建一个新的conda环境(可选,但推荐): bash conda create -n geoenv python=3.x anaconda conda activate geoenv 其中3.x是你希望使用的Python版本。 安装geopandas: 使用conda-forge频道来安装geopandas,因为它提供了许多地理空间相关的包。 bash conda install -c conda-forge geopandas 这条命令会自动安装geopandas及其所有依赖。 注意事项 如果你在安装过程中遇到任何问题,比如编译错误或依赖问题,请检查你的Python版本和pip/conda的版本是否是最新的,或者尝试在不同的环境中安装。 某些库(如GDAL)可能需要额外的系统级依赖,如地理空间库(如PROJ和GEOS)。这些依赖可能需要单独安装,具体取决于你的操作系统。 如果你在Windows上遇到问题,并且pip安装失败,尝试从Unofficial Windows Binaries for Python Extension Packages网站下载相应的wheel文件,并使用pip进行安装。 脚本示例 虽然你的问题主要是关于如何安装geopandas,但如果你想要一个Python脚本来重命名文件夹下的文件,在原始名字前面加上字符串"geopandas",以下是一个简单的示例: python import os # 指定文件夹路径 folder_path = 'path/to/your/folder' # 遍历文件夹中的文件 for filename in os.listdir(folder_path): # 构造原始文件路径 old_file_path = os.path.join(folder_path, filename) # 构造新文件名 new_filename = 'geopandas_' + filename # 构造新文件路径 new_file_path = os.path.join(folder_path, new_filename) # 重命名文件 os.rename(old_file_path, new_file_path) print(f'Renamed "{filename}" to "{new_filename}"') 请确保将'path/to/your/folder'替换为你想要重命名文件的实际文件夹路径。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值