2hutool实战:IoUtil 流操作工具类(获取getReader and getWriter)_hutool ioutil(1)

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

获得一个文件读取器

支持版本及以上
参数描述:
参数名描述
InputStream in
in 输入流
String charsetName
charsetName 字符集名称
返回值:

BufferedReader对象

参考案例:
		File src = new File("C:\\Users\\Administrator\\Desktop\\xuzhu/copyTest1.txt") ;
		FileInputStream fw = null;
		BufferedReader bufferedReader = null;
		try {
			//创建流
			fw = new FileInputStream(src);
			//新new BufferedReader对象,记得关闭回收
			bufferedReader = IoUtil.getReader(fw, "UTF-8");
			String str = null;
			//到达流末尾, 就返回null
			while((str = bufferedReader.readLine()) != null){
				System.out.println(str);
			}
		} catch (IOException e) {
			//抛出一个运行时异常(直接停止掉程序)
			throw new RuntimeException("运行时异常",e);
		} finally {
			try {
				//如果是空的 说明流创建失败 失败了不需要关闭
				if (fw != null) {
					fw.close();
				}
			} catch (Exception e) {
				//关闭资源失败 停止程序
				throw new RuntimeException("关闭资源失败");
			} finally {
				try {
					if (bufferedReader != null) {
						bufferedReader.close();
					}
				} catch (Exception e) {
					throw new RuntimeException("关闭资源失败");
				}
			}
		}

源码解析:
链接:待补充

方法明细

方法名称:cn.hutool.core.io.IoUtil.getReader(cn.hutool.core.io.BOMInputStream)
方法描述

从{@link BOMInputStream}中获取Reader

支持版本及以上

5.5.8

参数描述:
参数名描述
BOMInputStream in
in {@link BOMInputStream}
返回值:

{@link BufferedReader}

参考案例:
		File src = new File("C:\\Users\\Administrator\\Desktop\\xuzhu/copyTest1.txt") ;
		//BOM(Byte Order Mark)标识文件的编码,实际大小比数据多3个字节
		//  直接在记事本编辑数据保存,默认会给你的数据添加上BOM头,使你的文件的大小比实际数据多3个字节(utf-8编码)
		BOMInputStream fw = null;
		BufferedReader bufferedReader = null;
		try {
			//创建流
			fw = new BOMInputStream(new FileInputStream(src));
			//新new BufferedReader对象,记得关闭回收
			bufferedReader = IoUtil.getReader(fw);
			String str = null;
			//到达流末尾, 就返回null
			while((str = bufferedReader.readLine()) != null){
				System.out.println(str);
			}
		} catch (IOException e) {
			//抛出一个运行时异常(直接停止掉程序)
			throw new RuntimeException("运行时异常",e);
		} finally {
			try {
				//如果是空的 说明流创建失败 失败了不需要关闭
				if (fw != null) {
					fw.close();
				}
			} catch (Exception e) {
				//关闭资源失败 停止程序
				throw new RuntimeException("关闭资源失败");
			}finally {
				try {
					if (bufferedReader != null) {
						bufferedReader.close();
					}
				} catch (Exception e) {
					throw new RuntimeException("关闭资源失败");
				}
			}
		}

源码解析:
链接:待补充

方法明细

方法名称:cn.hutool.core.io.IoUtil.getReader(java.io.InputStream, java.nio.charset.Charset)
方法描述

获得一个Reader

支持版本及以上
参数描述:
参数名描述
InputStream in
in 输入流
Charset charset
charset 字符集
返回值:

BufferedReader对象

参考案例:

		File src = new File("C:\\Users\\Administrator\\Desktop\\xuzhu/copyTest1.txt") ;
		FileInputStream fw = null;
		BufferedReader bufferedReader =null;
		try {
			//创建流
			fw = new FileInputStream(src);
			//新new BufferedReader对象,记得关闭回收
			bufferedReader = IoUtil.getReader(fw,CharsetUtil.CHARSET_UTF_8);
			String str = null;
			//到达流末尾, 就返回null
			while((str = bufferedReader.readLine()) != null){
				System.out.println(str);
			}
		} catch (IOException e) {
			//抛出一个运行时异常(直接停止掉程序)
			throw new RuntimeException("运行时异常",e);
		} finally {
			try {
				//如果是空的 说明流创建失败 失败了不需要关闭
				if (fw != null) {
					fw.close();
				}
			} catch (Exception e) {
				//关闭资源失败 停止程序
				throw new RuntimeException("关闭资源失败");
			}finally {
				try {
					if (bufferedReader != null) {
						bufferedReader.close();
					}
				} catch (Exception e) {
					throw new RuntimeException("关闭资源失败");
				}
			}
		}

源码解析:
链接:待补充

方法明细

方法名称:cn.hutool.core.io.IoUtil.getReader(java.io.Reader)
方法描述

获得{@link BufferedReader}

如果是{@link BufferedReader}强转返回,否则新建。如果提供的Reader为null返回null

支持版本及以上

3.0.9

参数描述:
参数名描述
Reader reader
reader 普通Reader,如果为null返回null
返回值:

{@link BufferedReader} or null

参考案例:

		StringReader stringReader = null;
		BufferedReader bufferedReader =null;
		try {
			//创建流
			stringReader = new StringReader("1hello 小虚竹\n2hello 小虚竹");
			//新new BufferedReader对象,记得关闭回收
			bufferedReader = IoUtil.getReader(stringReader);
			String str = null;
			//到达流末尾, 就返回null
			while((str = bufferedReader.readLine()) != null){
				System.out.println(str);
			}
		} catch (IOException e) {
			//抛出一个运行时异常(直接停止掉程序)
			throw new RuntimeException("运行时异常",e);
		} finally {
			try {
				//如果是空的 说明流创建失败 失败了不需要关闭
				if (stringReader != null) {
					stringReader.close();
				}
			} catch (Exception e) {
				//关闭资源失败 停止程序
				throw new RuntimeException("关闭资源失败");
			}finally {
				try {
					if (bufferedReader != null) {
						bufferedReader.close();
					}
				} catch (Exception e) {
					throw new RuntimeException("关闭资源失败");
				}
			}
		}

在这里插入图片描述

源码解析:
链接:待补充

方法明细

方法名称:cn.hutool.core.io.IoUtil.getPushBackReader(java.io.Reader, int)
方法描述

获得{@link PushbackReader}

如果是{@link PushbackReader}强转返回,否则新建

支持版本及以上

3.1.0

参数描述:
参数名描述
Reader reader
reader 普通Reader
int pushBackSize
pushBackSize 推后的byte数
返回值:

{@link PushbackReader}

参考案例:
		StringReader stringReader = null;
		PushbackReader pushbackReader = null;
		try {
			stringReader = new StringReader("123456789");
			//PushbackReader允许调用者将一些数据源本身不包含的字符插入到流的任意位置
			pushbackReader = IoUtil.getPushBackReader(stringReader,100);
			StringBuilder stringBuilder = new StringBuilder();
			char[] buff = new char[3];
			//第一步,首先读取 “123”
			int n = pushbackReader.read(buff, 0, 3);
			stringBuilder.append(buff);
			System.out.println("第一步,读取了 " + n + " 个字符:");
			System.out.println(buff);
			//第二步,unread:abc, de, fghi
			pushbackReader.unread(new char[]{'a', 'b', 'c'});
			pushbackReader.unread(new char[]{'d', 'e'});
			pushbackReader.unread(new char[]{'f', 'g', 'h', 'i'});
			int c = 0;
			while ((c = pushbackReader.read()) != -1){
				stringBuilder.append((char) c);
			}
			System.out.println("最终读取的数据:" + stringBuilder.toString());
		}catch (IOException e){
			//抛出一个运行时异常(直接停止掉程序)
			throw new RuntimeException("运行时异常",e);
		} finally {
			try {
				//如果是空的 说明流创建失败 失败了不需要关闭
				if (stringReader != null) {
					stringReader.close();
				}
			} catch (Exception e) {
				//关闭资源失败 停止程序
				throw new RuntimeException("关闭资源失败");
			}finally {
				try {
					if (pushbackReader != null) {
						pushbackReader.close();
					}
				} catch (Exception e) {
					throw new RuntimeException("关闭资源失败");
				}
			}
		}

在这里插入图片描述

源码解析:
链接:待补充

方法明细

方法名称:cn.hutool.core.io.IoUtil.getUtf8Writer(java.io.OutputStream)
方法描述

获得一个Writer,默认编码UTF-8

支持版本及以上

5.1.6

参数描述:
参数名描述
OutputStream out
out 输入流
返回值:

OutputStreamWriter对象

参考案例:
		File dest = new File("C:\\Users\\Administrator\\Desktop\\xuzhu/getUtf8WriterTest.txt") ;
		FileOutputStream outputStream = null;
		OutputStreamWriter outputStreamWriter = null;
		try {
			//创建流
			outputStream = new FileOutputStream(dest);
			//新new OutputStreamWriter对象,记得关闭回收
			outputStreamWriter = IoUtil.getUtf8Writer(outputStream);
			String content = "1hello 小虚竹\n2hello 小虚竹";
			int c;
			for (int i = 0; i < content.length(); i++) {
				c = content.charAt(i);
				outputStreamWriter.write((char) c);

			}
			outputStreamWriter.flush();
		} catch (IOException e) {
			//抛出一个运行时异常(直接停止掉程序)
			throw new RuntimeException("运行时异常",e);
		} finally {
			try {
				//如果是空的 说明流创建失败 失败了不需要关闭
				if (outputStream != null) {
					outputStream.close();
				}
			} catch (Exception e) {
				//关闭资源失败 停止程序
				throw new RuntimeException("关闭资源失败");
			}finally {
				try {
					if (outputStreamWriter != null) {
						outputStreamWriter.close();
					}
				} catch (Exception e) {
					throw new RuntimeException("关闭资源失败");
				}
			}
		}

在这里插入图片描述

源码解析:
链接:待补充

方法明细

方法名称:cn.hutool.core.io.IoUtil.getWriter(java.io.OutputStream, java.lang.String)
方法描述

获得一个Writer

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

(https://img-blog.csdnimg.cn/20210607195339949.png#pic_center)

源码解析:
链接:待补充

方法明细

方法名称:cn.hutool.core.io.IoUtil.getWriter(java.io.OutputStream, java.lang.String)
方法描述

获得一个Writer

[外链图片转存中…(img-KjhZPfKU-1715666029907)]
[外链图片转存中…(img-5svsw1qd-1715666029908)]
[外链图片转存中…(img-YMqrcozr-1715666029908)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以戳这里获取

  • 12
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,您可以按照以下步骤使用Hutool的ExcelUtil工具类来读取Excel文件并生成SQL语句: 1. 首先,确保您已经导入了Hutool的相关依赖。 2. 使用ExcelUtil类的getReader方法获取ExcelReader对象,代码示例: ```java ExcelReader reader = ExcelUtil.getReader("path/to/your/excel/file.xlsx"); ``` 这里的"path/to/your/excel/file.xlsx"是您要读取的Excel文件的路径。 3. 使用ExcelReader对象的read方法读取Excel文件中的数据,代码示例: ```java List<List<Object>> dataList = reader.read(); ``` 这里的dataList是一个二维列表,包含了Excel文件中所有行和列的数据。 4. 遍历dataList,生成SQL语句。您可以根据Excel文件的结构和需求自定义生成SQL语句的逻辑。以下是一个简单的示例: ```java StringBuilder sqlBuilder = new StringBuilder(); for (List<Object> row : dataList) { String column1 = row.get(0).toString(); String column2 = row.get(1).toString(); String column3 = row.get(2).toString(); String sql = String.format("INSERT INTO table_name (column1, column2, column3) VALUES ('%s', '%s', '%s');", column1, column2, column3); sqlBuilder.append(sql).append("\n"); } String sqlStatements = sqlBuilder.toString(); ``` 这里的table_name是您要插入数据的表名,column1、column2、column3是Excel文件中对应的列名。 5. 最后,您可以将生成的SQL语句保存到文件或执行其他操作。 请注意,上述示例仅为生成SQL语句的简单示例,您可能需要根据实际情况进行适当的修改和扩展。 希望能帮到您!如有任何问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值