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

技术活,该赏
关注+一键三连(点赞,评论,收藏)再看,养成好习惯

hutool实战(带你掌握里面的各种工具)目录


用途:IO工具类(获取getReader and getWriter)

使用场景

IO工具类只是辅助流的读写,并不负责关闭流。原因是流可能被多次读写,读写关闭后容易造成问题。

(获取getReader and getWriter)

(获取getReader and getWriter)

(获取getReader and getWriter)

项目引用

此博文的依据:hutool-5.6.5版本源码

        <dependency>
			<groupId>cn.hutool</groupId>
			<artifactId>hutool-core</artifactId>
			<version>5.6.5</version>
		</dependency>

方法摘要

方法描述
cn.hutool.core.io.IoUtil.getUtf8Reader(java.io.InputStream)
获得一个文件读取器,默认使用UTF-8编码
cn.hutool.core.io.IoUtil.getReader(java.io.InputStream, java.lang.String)
获得一个文件读取器
cn.hutool.core.io.IoUtil.getReader(cn.hutool.core.io.BOMInputStream)
从{@link BOMInputStream}中获取Reader
cn.hutool.core.io.IoUtil.getReader(java.io.InputStream, java.nio.charset.Charset)
获得一个Reader
cn.hutool.core.io.IoUtil.getReader(java.io.Reader)
获得{@link BufferedReader}<br> 如果是{@link BufferedReader}强转返回,否则新建。如果提供的Reader为null返回null
cn.hutool.core.io.IoUtil.getPushBackReader(java.io.Reader, int)
获得{@link PushbackReader}<br> 如果是{@link PushbackReader}强转返回,否则新建
cn.hutool.core.io.IoUtil.getUtf8Writer(java.io.OutputStream)
获得一个Writer,默认编码UTF-8
cn.hutool.core.io.IoUtil.getWriter(java.io.OutputStream, java.lang.String)
获得一个Writer
cn.hutool.core.io.IoUtil.getWriter(java.io.OutputStream, java.nio.charset.Charset)
获得一个Writer

方法明细

方法名称:cn.hutool.core.io.IoUtil.getUtf8Reader(java.io.InputStream)

方法描述

获得一个文件读取器,默认使用UTF-8编码

支持版本及以上

5.1.6

参数描述:

参数名描述
InputStream in
in 输入流

返回值:

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.getUtf8Reader(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.lang.String)

方法描述

获得一个文件读取器

支持版本及以上

参数描述:

参数名描述
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}<br>
如果是{@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}<br>
如果是{@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

支持版本及以上

参数描述:

参数名描述
OutputStream out
out 输入流
String charsetName
charsetName 字符集

返回值:

OutputStreamWriter对象

参考案例:

		File dest = new File("C:\\Users\\Administrator\\Desktop\\xuzhu/getWriterTest.txt") ;
		FileOutputStream outputStream = null;
		OutputStreamWriter outputStreamWriter = null;
		try {
			//创建流
			outputStream = new FileOutputStream(dest);
			//新new OutputStreamWriter对象,记得关闭回收
			outputStreamWriter = IoUtil.getWriter(outputStream,"UTF-8");
			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.nio.charset.Charset)

方法描述

获得一个Writer

支持版本及以上

参数描述:

参数名描述
OutputStream out
out 输入流
Charset charset
charset 字符集

返回值:

OutputStreamWriter对象

参考案例:

		File dest = new File("C:\\Users\\Administrator\\Desktop\\xuzhu/getWriterTest1.txt") ;
		FileOutputStream outputStream = null;
		OutputStreamWriter outputStreamWriter = null;
		try {
			//创建流
			outputStream = new FileOutputStream(dest);
			//新new OutputStreamWriter对象,记得关闭回收
			outputStreamWriter = IoUtil.getWriter(outputStream,CharsetUtil.CHARSET_UTF_8);
			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("关闭资源失败");
				}
			}
		}

在这里插入图片描述

源码解析:

链接:待补充
好的,您可以按照以下步骤使用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语句的简单示例,您可能需要根据实际情况进行适当的修改和扩展。 希望能帮到您!如有任何问题,请随时提问。
评论 62
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小虚竹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值