zip文件的读取和写入

Zip文件的读取

ZipInputStream的基本用法:

首先要创建一个ZipInputStream,通常是传入一个FileInputStream作为数据源,然后循环调用getNextEntry(),当返回值为null时,表示zip流读取结束。

一个ZipEntry表示一个压缩文件或目录,如果是压缩文件,我们就用read()方法进行读取,当返回值为-1时,读取结束。

代码实现

public class Main {
	public static void main(String[] args) {
		try (ZipInputStream in = new ZipInputStream(new FileInputStream("C:\\IO流\\Test.zip"),Charset.forName("gbk"))) {
			ZipEntry entry = null;
			//提取压缩文件中的每个子文件
			while((entry = in.getNextEntry())!=null) {
                System.out.println(entry.getName());
                int data = -1;
                while((data = in.read())!= -1){
                    System.out.println(data);
                }
			}
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}

接下来我们使用ZipInputStream输入流,自己实现一个解压缩功能

功能实现:对一个zip文件进行解压缩

实现步骤:1,创建解压缩目录,获取zip文件的名称,根据zip文件名称,提取压缩目录的名称,创建解压缩目录,随后创建目录。

                  2,遍历并读取Zip文件中的每个子文件,创建一个缓冲输出流,将Zip文件中读取的文件字节写入新的文件中,需要注意的是:每创建一个输出流,我们都需要手动的将其关闭,当写入的文件字节较少时,会出现缓冲区的字节无法正常写入。

public class Main {
	public static void main(String[] args) {
		//要进行解压缩的zip文件
		File zipFile = new File("C:\\IO流\\Test.zip");
		
		//1.创建解压缩目录
		//获取zip文件的名称
		String zipFileName = zipFile.getName();
		
		//根据zip文件名称,提取压缩目录的名称
		String targetFileName = zipFileName.substring(0,zipFileName.indexOf("."));
		
		//创建解压缩目录
		File targetDir = new File(zipFile.getParent() + "\\" + targetFileName);
		
		if(!targetDir.exists()) {
			targetDir.mkdir();//创建目录
		}
		
		//2.解析读取zip文件
		try (
		 ZipInputStream in = new ZipInputStream(new FileInputStream(zipFile),Charset.forName("gbk"))) {
			//遍历Zip文件中的每个子文件
			ZipEntry zipEntry = null;
			while((zipEntry = in.getNextEntry())!=null) {
				//获取zip压缩包中的子文件名称
				String zipEntryFileName = zipEntry.getName();
                //创建该文件的输出流
				String zipFilePath = targetDir.getPath() + "\\" + zipEntryFileName;
				//輸出流定义在try()块,结束自动清空缓冲区并关闭
				try(BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(zipFilePath))){ ;
					// 读取该子文件的字节内容
					byte[] buff = new byte[1024];
					int len = -1;
					while ((len = in.read(buff)) != -1) {
                        bos.write(buff, 0, len);
					}
				 }
			   }
        } catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
	}
}

Zip文件的写入

            ZipOutputStream是一种FilterOutputStream,它可以直接写入内容到zip包。我们要先创建一个ZipOutputStream,通常是包装一个FileOutStream,然后,没写入一个文件前,先调用putNextEntry( ),然后用write()写入byte[ ]数据,写入完毕后调用closeEntry( ),结束这个文件的打包。

下来我们利用ZipOutputStream输出流实现指定功能:将指定文件写入zip文件

功能实现:将一个文件目录进行压缩。

实现步骤:1,获取并遍历原始目录下的子文件列表。

                  2,将原始文件的字节内容,写入zip压缩包。

我们在进行zip文件的写入时,需要注意的是写入的zip压缩包应与原始目录在同一父级目录下。

public class Main {
	public static void main(String[] args) {
		//原始目录
		File rootDir = new File("C:\\IO流\\Test");
		
		//将原始目录中的文件,写入zip压缩文件
		try ( ZipOutputStream out = new ZipOutputStream(new FileOutputStream(rootDir.getParent()+"\\"+rootDir.getName()+".zip"))) {
			//获取并遍历原始目录下的子文件列表
			File[] files = rootDir.listFiles();
			for (File file : files) {
				//创建一个ZipEntry
				out.putNextEntry(new ZipEntry(file.getName()));
				
				//将原始文件的字节内容,写入zip压缩包
				out.write(Files.readAllBytes(file.toPath()));
				
				//结束当前ZipEntry
				out.closeEntry();
			}
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
您可以使用Java的ZipInputStream类来读取zip压缩文件,然后将数据写入数据库。以下是一个简单的示例代码: ```java import java.io.FileInputStream; import java.io.IOException; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; import java.util.zip.ZipEntry; import java.util.zip.ZipInputStream; public class ZipFileReader { public static void main(String[] args) { String zipFilePath = "path/to/your/zip/file.zip"; String dbUrl = "jdbc:mysql://localhost:3306/mydatabase"; String dbUsername = "your-username"; String dbPassword = "your-password"; try { // 打开数据库连接 Connection conn = DriverManager.getConnection(dbUrl, dbUsername, dbPassword); // 创建插入数据的SQL语句 String insertQuery = "INSERT INTO your_table_name (file_name, file_data) VALUES (?, ?)"; // 创建PreparedStatement对象 PreparedStatement pstmt = conn.prepareStatement(insertQuery); // 创建ZipInputStream对象 ZipInputStream zipInput = new ZipInputStream(new FileInputStream(zipFilePath)); // 读取zip文件中的每个条目 ZipEntry entry = zipInput.getNextEntry(); while (entry != null) { // 读取条目的文件名和数据 String fileName = entry.getName(); byte[] fileData = new byte[(int) entry.getSize()]; zipInput.read(fileData); // 设置参数并执行插入语句 pstmt.setString(1, fileName); pstmt.setBytes(2, fileData); pstmt.executeUpdate(); // 关闭当前条目,准备读取下一个条目 zipInput.closeEntry(); entry = zipInput.getNextEntry(); } // 关闭ZipInputStream、PreparedStatement和数据库连接 zipInput.close(); pstmt.close(); conn.close(); System.out.println("数据成功写入数据库!"); } catch (IOException | SQLException e) { e.printStackTrace(); } } } ``` 请将代码中的以下内容替换为您自己的信息: - `zipFilePath`:您的zip文件的路径。 - `dbUrl`:您的数据库URL。 - `dbUsername`:您的数据库用户名。 - `dbPassword`:您的数据库密码。 - `your_table_name`:您要插入数据的表名。 这段代码将逐个读取zip文件中的条目,并将每个条目的文件名和数据插入到数据库中。您需要根据自己的需求修改代码以适应您的数据库结构和数据处理逻辑。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值