压缩文件的解析方式

一、解压缩zip格式

步骤:

1.根据压缩文件原始路径(字符串),创建源文件对象(File对象)

2.创建根目录对象,传入源文件的根目录

3.判断根目录,是否已经存在

        ①如果存在,则删除;

        ②如果不存在,则创建根目录。

4.可以用ZipInputStream对象,进行zip格式的压缩文件

首先创建一个ZipInputStream对象,zip文件中的每一个子文件或者子目录都是一个ZipEntry类型的对象。通过ZipInputStream对象调用getNextEntry()方法获取这些文件到输入流中。然后通过输入流和输出流完成文件的读写。

5.遍历压缩包中的每个子目录或子文件(ZipEntry类型的对象)

6.创建子目录或子文件(File对象)

7.创建子目录或者子文件

        ①如果zipEntry对象是目录的话,那就创建子目录

        ②如果zipEntry对象是文件的话,那就创建子文件

8.读取当前压缩包的子文件,并通过输出流out写入新子文件中

具体代码实现如下:

public class Text02 {
	public static void main(String[] args) {
		String path = "D:\\001\\easyftp-server-1.7.0.10-cn.zip";
		if (path.endsWith(".zip")) {
			unzip(path);
		} else if (path.endsWith(".rar")) {
			unrar(path);
		}
	}

	// 解压缩zip格式
	public static void unzip(String path) {
		// 根据原始路径(字符串),创建源文件(File对象)
		File sourceFile = new File(path);

		// 创建根目录对象
		String sourceFileName = sourceFile.getName();//压缩包的名字
		File rootDir = new File(
				sourceFile.getParent() + "\\" + sourceFileName.substring(0, sourceFileName.lastIndexOf(".")));//传入源文件的根目录

		// 判断根目录,是否已经存在
		if (rootDir.exists()) {
			// 如果存在,则删除
//			rootDir.delete();//仅能删除空目录

			// 使用commns-io包提供的FileUtils工具类进行删除
			try {
				FileUtils.deleteDirectory(rootDir);
			} catch (IOException e) {

				e.printStackTrace();
			}

		}
		// 创建根目录
		rootDir.mkdir();

		// ZipInputStream:用于进行zip格式的压缩文件输入流
		try (ZipInputStream in = new ZipInputStream(new FileInputStream(sourceFile));) {

			// 遍历压缩包中的每个子目录或子文件(ZipEntry类型的对象)
			ZipEntry zipEntry = null;
			while ((zipEntry = in.getNextEntry()) != null) {
//				System.out.println(zipEntry.getName());\
				// 创建子目录或子文件(File对象)
				File file = new File(rootDir.getPath() + "\\" + zipEntry.getName());

				if (zipEntry.isDirectory()) {
					// 物理磁盘创建子目录
					file.mkdir();
				} else {
					// 物理磁盘创建子文件
					file.createNewFile();
					
					//读取当前压缩包的子文件,并通过输出流out写入新子文件中
					FileOutputStream out = new FileOutputStream(file);
					byte[] buff = new byte[1024];
					int len = -1;
					while((len=in.read(buff))!=-1) {
						out.write(buff,0,len);
					}
					out.close();
				}
			}
		} catch (IOException e1) {
			e1.printStackTrace();
		}

	}
}

二、解压缩rar格式

步骤:

1.创建源文件对象

2.创建解压缩的根目录对象,

通常是与zip文件在同一目录下,通过用zip的文件的父目录与zip文件的文件名作为数据源,并调用mkdir()方法创建目录。

        ①如果根目录存在的话,就删掉

        ②如果根目录不存在,就创建根目录

3.创建Archive对象,用于读取rar压缩文件格式

解析并读取zip压缩文件,创建一个ZipInputStream,传入一个FileInputStream作为数据源,然后循环调用getNextEntry(),遍历zip文件的每一个子文件和子目录,每次循环获取子文件名或子目录名,并创建文件的输出流,调用write()方法,读取文件内容并写入输出流。

4.获取压缩文件中的所有子目录或子文件(FileHeader对象)

5.按照子目录(子文件)名称排序

6.遍历子目录和子文件

7.创建子目录或者子文件

        ①遍历结果是目录,那就创建新子目录

        ②遍历结果是文件,那就创建子文件

8.获取压缩包中的自我年间输入流,复制文件输入流至新子文件

具体代码实现如下:

public class Text02 {
	public static void main(String[] args) {
//		String path = "D:\\001\\easyftp-server-1.7.0.10-cn.zip";
		String path = "D:\\001\\实验案例.rar";
		if (path.endsWith(".zip")) {
			unzip(path);
		} else if (path.endsWith(".rar")) {
			unrar(path);
		}
	}

	
	//解压缩rar格式
	public static void unrar(String path) {
		//1.创建解压缩的根目录
		
		//1.创建源文件对象
		File rarFile = new File(path);
		
		//2.创建解压缩的根目录对象
		File rootDir = new File(rarFile.getParent()+"\\"+rarFile.getName().substring(0, rarFile.getName().indexOf(".")));
		//3如果根目录存在的话,就删掉
		if(rootDir.exists()) {
			try {
				FileUtils.deleteDirectory(rootDir);
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
		//3.创建根目录
		rootDir.mkdir();
		
		//创建Archive对象,用于读取rar压缩文件格式
		try (Archive archive = new Archive(new FileInputStream(path))) {
			
			//获取压缩文件中的所有子目录或子文件(FileHeader对象)
			List<FileHeader> fileheaderList = archive.getFileHeaders();
			
			//按照子目录(子文件)名称排序!
			fileheaderList.sort(new Comparator<FileHeader>() {
//!
				@Override
				public int compare(FileHeader o1, FileHeader o2) {
					
					return o1.getFileName().compareTo(o2.getFileName());
				}
				
			});
			
			//遍历子目录和子文件
			for(FileHeader fd: fileheaderList) {
				File f = new File(rootDir.getPath()+"\\"+fd.getFileName());
				
				if(fd.isDirectory()) {
					//创建新子目录
					f.mkdir();
				}else {
					//创建新子目录
					f.createNewFile();
					
					//获取压缩包中的子文件输入流
					InputStream in = archive.getInputStream(fd);
					
					//复制文件输入流至新子文件
					FileUtils.copyInputStreamToFile(in, f);
				}
			}
		} catch (RarException | IOException e) {
			e.printStackTrace();
		}
	}
}

三、压缩文件

步骤:

1.首先创建File对象files引用原始目录

2.然后创建一个ZipOutputStream,传入一个FileOutputStream作为数据源

3.调用listFiles()方法,获取并遍历原始目录下的子文件列表,每次循环创建一个ZipEntry,每写入一个文件前,调用putNextEntry()方法

4.然后将源文件的字节内容,写入zip压缩包

需要注意,每次写完文件,必须调用closeEntry()结束当前ZipEntry。

//压缩文件
public class Text05 {
	public static void main(String[] args) {
		//所在目录
		File dir = new File("D:\\001\\001");
		
		//获取所有原始子文件
		File[] files = dir.listFiles();
		
		//创建zip压缩文件的输出流
		try (ZipOutputStream out = new ZipOutputStream(
				new FileOutputStream(dir.getPath()+"\\"+dir.getName()+".zip"))) {
		
			//遍历所有原始子文件
			for(File f:files) {
				//写入一个压缩包中的子文件(ZipEntry对象)
				out.putNextEntry(new ZipEntry(f.getName()));
				
				//写入字节内容
				out.write(Files.readAllBytes(f.toPath()));
				
				//关闭压缩包的子文件
				out.closeEntry();
			}
		
		} catch (IOException e) {
			e.printStackTrace();
		}
		
	}

}

SHP文件是存储地理空间数据的一种常见的GIS矢量数据格式。通常情况下,SHP文件是由多个文件组成的集合,包括.shp、.shx和.dbf文件。其中,.shp文件包含了空间几何对象的几何信息,.shx文件是shp文件的索引文件,用于快速访问.shp文件中的几何对象,.dbf文件则存储了与几何对象相关的属性数据。 要对SHP文件进行解析,首先需要了解其文件结构。可以使用第三方库或软件进行解析,如GDAL、ArcGIS、QGIS等。以GDAL为例,可以使用GDAL库中的Open函数读取.shp文件,并获取其中的几何对象和属性数据。通过对shp文件的读取,可以了解其坐标系信息、几何对象类型(如点、线、面等)、坐标点的位置等。 对于压缩的SHP文件,通常是将多个SHP文件进行压缩打包而成的。解析时需要先解压缩文件,即还原出原始的.shp、.shx和.dbf文件。然后再按照上述方法对解压缩后的文件进行解析。 在解析SHP文件时,还可以进行一些其他的操作,比如对空间几何对象进行空间分析、属性查询等。通过解析SHP文件,可以获取到地理数据中的几何信息和属性信息,进而进行地理空间分析和可视化等操作。 总之,解析SHP文件是指对其文件结构进行解析,提取出其中的几何对象和属性数据。通过了解SHP文件文件结构和使用相关的库或软件,可以对SHP文件进行解析和进一步的操作。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值