Advertisement

使用org.apache.tools.zip解决解压时的乱码问题

  •  5星
  •     浏览量: 0
  •     大小:None
  •      文件类型:None


简介:
本教程介绍如何利用Java中的org.apache.tools.zip库有效处理文件解压缩过程中遇到的编码问题,确保文件内容正确显示。 ```java package com.cliff.common; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import org.apache.tools.zip.ZipEntry; import org.apache.tools.zip.ZipFile; import org.apache.tools.zip.ZipOutputStream; /** * 类名: ZipUtil.java * 描述:压缩/解压缩zip包处理类 * 创建者:XXX * 创建日期:2015年5月7日 - 下午1:35:02 * 版本: V0.1 */ public class ZipUtil { /** * 功能描述:压缩文件 * 创建者:XXX * 创建日期: 2015年5月7日 - 下午1:35:18 * 版本: V0.1 */ public static void zip(String directory) throws FileNotFoundException, IOException { zip(, null, directory); } /** * 功能描述:压缩文件 * 创建者:XXX * 创建日期: 2015年5月7日 - 下午1:36:03 * 版本: V0.1 */ public static void zip(String zipFileName, String relativePath, String directory) throws FileNotFoundException, IOException { String fileName = zipFileName; if (fileName == null || fileName.trim().equals()) { File temp = new File(directory); if (temp.isDirectory()) { fileName = directory + .zip; } else { if (directory.indexOf(.) > 0) { fileName = directory.substring(0, directory.lastIndexOf(.))+ zip; } else { fileName = directory + .zip; } } } ZipOutputStream zos = new ZipOutputStream(new FileOutputStream(fileName)); try { zip(zos, relativePath, directory); } catch (IOException ex) { throw ex; } finally { if (null != zos) { zos.close(); } } } /** * 功能描述:压缩文件 * 创建者:XXX * 创建日期: 2015年5月7日 - 下午1:37:55 * 版本: V0.1 */ private static void zip(ZipOutputStream zos, String relativePath, String absolutPath) throws IOException { File file = new File(absolutPath); if (file.isDirectory()) { File[] files = file.listFiles(); for (int i = 0; i < files.length; i++) { File tempFile = files[i]; if (tempFile.isDirectory()) { String newRelativePath = relativePath + tempFile.getName() + File.separator; createZipNode(zos, newRelativePath); zip(zos, newRelativePath, tempFile.getPath()); } else { zipFile(zos, tempFile, relativePath); } } } else { zipFile(zos, file, relativePath); } } /** * 功能描述:压缩文件 * 创建者:XXX * 创建日期: 2015年5月7日 - 下午1:38:46 * 版本: V0.1 */ private static void zipFile(ZipOutputStream zos, File file, String relativePath) throws IOException { ZipEntry entry = new ZipEntry(relativePath + file.getName()); zos.putNextEntry(entry); InputStream is = null; try { is = new FileInputStream(file); int BUFFERSIZE = 2 << 10; int length = 0; byte[] buffer = new byte[BUFFERSIZE]; while ((length = is.read(buffer, 0, BUFFERSIZE)) >= 0) { zos.write(buffer, 0, length); } zos.flush(); zos.closeEntry(); } catch (IOException ex) { throw ex; } finally { if (null != is) { is.close(); } } } /** * 功能描述:创建目录 * 创建者:XXX * 创建日期: 2015年5月7日 - 下午1:39:12 * 版本: V0.1 */ private static void createZipNode(ZipOutputStream zos, String relativePath) throws IOException { ZipEntry zipEntry = new ZipEntry(relativePath); zos.putNextEntry(zipEntry); zos.closeEntry(); } /** * 功能描述:解压缩文件 * 创建者:XXX * 创建日期: 201

全部评论 (0)

还没有任何评论哟~
客服
客服
  • 使org.apache.tools.zip
    优质
    本教程介绍如何利用Java中的org.apache.tools.zip库有效处理文件解压缩过程中遇到的编码问题,确保文件内容正确显示。 ```java package com.cliff.common; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import org.apache.tools.zip.ZipEntry; import org.apache.tools.zip.ZipFile; import org.apache.tools.zip.ZipOutputStream; /** * 类名: ZipUtil.java * 描述:压缩/解压缩zip包处理类 * 创建者:XXX * 创建日期:2015年5月7日 - 下午1:35:02 * 版本: V0.1 */ public class ZipUtil { /** * 功能描述:压缩文件 * 创建者:XXX * 创建日期: 2015年5月7日 - 下午1:35:18 * 版本: V0.1 */ public static void zip(String directory) throws FileNotFoundException, IOException { zip(, null, directory); } /** * 功能描述:压缩文件 * 创建者:XXX * 创建日期: 2015年5月7日 - 下午1:36:03 * 版本: V0.1 */ public static void zip(String zipFileName, String relativePath, String directory) throws FileNotFoundException, IOException { String fileName = zipFileName; if (fileName == null || fileName.trim().equals()) { File temp = new File(directory); if (temp.isDirectory()) { fileName = directory + .zip; } else { if (directory.indexOf(.) > 0) { fileName = directory.substring(0, directory.lastIndexOf(.))+ zip; } else { fileName = directory + .zip; } } } ZipOutputStream zos = new ZipOutputStream(new FileOutputStream(fileName)); try { zip(zos, relativePath, directory); } catch (IOException ex) { throw ex; } finally { if (null != zos) { zos.close(); } } } /** * 功能描述:压缩文件 * 创建者:XXX * 创建日期: 2015年5月7日 - 下午1:37:55 * 版本: V0.1 */ private static void zip(ZipOutputStream zos, String relativePath, String absolutPath) throws IOException { File file = new File(absolutPath); if (file.isDirectory()) { File[] files = file.listFiles(); for (int i = 0; i < files.length; i++) { File tempFile = files[i]; if (tempFile.isDirectory()) { String newRelativePath = relativePath + tempFile.getName() + File.separator; createZipNode(zos, newRelativePath); zip(zos, newRelativePath, tempFile.getPath()); } else { zipFile(zos, tempFile, relativePath); } } } else { zipFile(zos, file, relativePath); } } /** * 功能描述:压缩文件 * 创建者:XXX * 创建日期: 2015年5月7日 - 下午1:38:46 * 版本: V0.1 */ private static void zipFile(ZipOutputStream zos, File file, String relativePath) throws IOException { ZipEntry entry = new ZipEntry(relativePath + file.getName()); zos.putNextEntry(entry); InputStream is = null; try { is = new FileInputStream(file); int BUFFERSIZE = 2 << 10; int length = 0; byte[] buffer = new byte[BUFFERSIZE]; while ((length = is.read(buffer, 0, BUFFERSIZE)) >= 0) { zos.write(buffer, 0, length); } zos.flush(); zos.closeEntry(); } catch (IOException ex) { throw ex; } finally { if (null != is) { is.close(); } } } /** * 功能描述:创建目录 * 创建者:XXX * 创建日期: 2015年5月7日 - 下午1:39:12 * 版本: V0.1 */ private static void createZipNode(ZipOutputStream zos, String relativePath) throws IOException { ZipEntry zipEntry = new ZipEntry(relativePath); zos.putNextEntry(zipEntry); zos.closeEntry(); } /** * 功能描述:解压缩文件 * 创建者:XXX * 创建日期: 201
  • Python3.4使pymssql
    优质
    本篇文章主要介绍了解决Python 3.4版本中使用pymssql模块进行数据库操作时出现乱码问题的方法和技巧。通过调整字符编码设置,可以有效避免中文显示异常的情况,保证数据正确读取与展示。 在项目中发现这样一个问题:SQL Server数据库编码为GBK,在使用Python 3.4+pymssql查询时出现中文乱码现象。经过一番思考后找到了解决办法,并分享如下: ```python conn = pymssql.connect(host=192.168.122.141, port=1433, user=myshop, password=oyf20140208HH, database=mySHOPCMStock, charset=utf8, as_dict=True) cur = conn.cursor() sql = select top 10 [ID], [Name] from [ # 注意:SQL语句未完成,可能需要补充表名或其它内容 ``` 这段代码通过指定连接字符集为`utf-8`解决了中文乱码的问题。
  • ZIP出现
    优质
    本文详细介绍了在使用ZIP进行文件解压缩过程中遇到乱码问题的原因及解决方案。通过调整编码设置和选择合适的解压工具,可以有效避免此类问题的发生。 解决zip解压缩乱码的方法通常包括处理常见字符串编码问题的方案,这些方法易于上手,并且支持二次开发与封装。
  • 文件中文
    优质
    本文详细介绍了在解压缩文件过程中遇到的中文乱码问题,并提供了解决方法和预防措施。 在IT行业中,中文乱码问题是一个常见的困扰,尤其是在处理压缩文件时。本段落将详细探讨如何使用7-Zip软件解压包含中文名称的文件以解决乱码问题,并介绍在C#编程环境中如何应对这一挑战。 首先,我们需要了解为什么会出现乱码现象:这是由于字符编码不一致导致的问题。当创建压缩文件时采用了一种特定的字符编码(如GBK),而在解压该文件的应用程序或系统中使用了另一种不同的编码方式(比如UTF-8)时,就会产生中文乱码。 解决7-Zip软件在解压过程中遇到的中文乱码问题的方法如下: 1. **设置正确的字符集**:进入7-Zip的配置界面,在“编码”选项里选择一种适合你压缩文件类型的编码。例如,如果你知道原文件使用的是GBK编码,则应在此处将它设为GBK。 2. **采用命令行解压方式**:通过在命令提示符中输入带有指定字符集参数的7-Zip命令来解决乱码问题。比如,执行`7z x -scsGBK yourfile.zip` 可以确保使用GBK编码正确地提取文件内容。 3. **升级到最新版本**:定期检查并安装最新的7-Zip更新,因为新发布的软件可能已经修复了与字符集相关的问题和错误。 4. **验证路径设置及名称格式**:确认你的操作系统支持中文字符,并且没有对路径长度的限制。这有助于防止因文件名过长或不正确而导致解压失败的情况发生。 在C#编程环境中,同样可以通过特定库来处理这样的问题,如SharpCompress或者System.IO.Compression。以下是使用GBK编码进行解压缩的一个示例: ```csharp using System; using System.IO; using SharpCompress.Archives.Zip; var archive = ZipArchive.Open(yourfile.zip, ArchiveEncoding.Gbk); foreach (var entry in archive.Entries) { if (!entry.Name.StartsWith(., StringComparison.OrdinalIgnoreCase)) { var destinationPath = Path.Combine(解压目录, entry.FullName); entry.WriteToDirectory(解压目录, new ExtractionOptions { ExtractEntryToFile = true, Encoding = System.Text.Encoding.GetEncoding(GBK) }); } } ``` 在这个示例中,我们使用了SharpCompress库的ZipArchive类来打开一个zip文件,并在提取每个条目时指定了正确的字符编码(即GBK)。如果选择其他压缩解压库如System.IO.Compression,则可以采用类似的方法设置适当的字符集。 总之,在处理中文乱码问题时的关键在于识别并匹配正确的字符编码。无论是使用7-Zip还是C#编程,都需要保证在解压过程中使用的编码方式与创建压缩文件的原始编码一致,这样才能确保正确显示包含中文名称的内容。同时保持软件和库版本更新也是解决问题的重要环节之一。
  • 方法 方法 方法 方法 方法
    优质
    本文章主要介绍了解决乱码问题的各种有效方法,包括编码转换、字符集设置等技巧,帮助读者轻松应对不同场景下的乱码困扰。 乱码问题的解决方法 遇到乱码问题时,可以尝试以下几种解决方案: 1. 检查文件编码:确保文件使用正确的字符集格式(如UTF-8、GBK等)打开。 2. 设置浏览器兼容模式或更改语言设置以匹配网页内容所使用的字符集。 3. 在程序中明确指定读取和输出时的文本编码方式,避免默认值导致乱码情况发生。 以上就是解决乱码问题的一些常用方法。
  • Python ZIP包中文方案
    优质
    本文介绍了在使用Python解压含有中文路径或文件名的ZIP包时常遇到的乱码问题,并提供了有效的解决方法。 乱码的原因是由于使用ZipFile模块导出中文文件名时解码错误,在Windows系统上会出现此问题,不确定在Linux环境下是否也会出现。 解决方法: 1. 创建一个文件名映射表(这种方法不太方便,仅适用于少量文件夹的情况)。 2. 修改源代码中的解码格式以适应中文字符(修改起来比较麻烦,并且可能会引发其他错误)。 3. 通过自己编写代码来创建和写入文件(推荐此方法) 下面是一个自行处理的示例: ```python with zipfile.ZipFile(file=zip_save_path, mode=r) as zf: # 解压到指定目录,首先需要创建一个解压缩的目标文件夹 os.mkdir(unzip_dir_path) for old_name in: ``` 注意:代码中的`for old_name in`可能不完整或有误。请根据实际需求完成该循环体内的逻辑处理。
  • 优质
    本文章详细介绍了如何解决计算机系统中常见的乱码问题,通过排查字符编码不匹配的原因并提供具体解决方案,帮助读者轻松应对各种乱码情况。 如果电脑换成Unicode编码模式后仍然无法解决问题,可以使用一个能够翻译乱码的软件作为替代方案,它可以解决各种乱码问题。
  • C++调Python中文
    优质
    本文章介绍了解决在C++中调用Python接口时出现中文乱码问题的方法,提供了详细的解决方案和代码示例。适合需要进行语言交互开发的技术人员参考。 在跨语言交互中,特别是在C++与Python之间进行数据传递时,编码问题是一个常见的挑战。本段落将深入探讨如何解决C++调用Python时遇到的中文乱码问题。 我们需要理解编码的基础知识。C++标准库没有指定默认的字符编码,在Windows环境下,Visual Studio的默认源代码编码通常是GBK(或其变体GB18030)。另一方面,Python 3默认使用UTF-8编码,这是国际上广泛接受的多语言字符集。当C++和Python之间传递包含中文字符的数据时,如果不进行适当的编码转换,就可能导致乱码。 为了解决这个问题,在C++代码中确保字符串以正确的编码传递至关重要。在Windows环境下可以利用`#pragma execution_character_set(GB2312)`声明源代码的字符集为GBK,但这并不能解决从C++到Python的数据传输中的编码问题。因此,我们需要编写一个函数来将GBK编码的字符串转换为UTF-8编码。 以下是一个示例函数用于实现这一目的: ```cpp string GbkToUtf8(const char* src_str) { int len = MultiByteToWideChar(CP_ACP, 0, src_str, -1, NULL, 0); wchar_t* wstr = new wchar_t[len + 1]; memset(wstr, 0, len + 1); MultiByteToWideChar(CP_ACP, 0, src_str, -1, wstr, len); len = WideCharToMultiByte(CP_UTF8, 0, wstr, -1, NULL, 0, NULL, NULL); char* str = new char[len + 1]; memset(str, 0, len + 1); WideCharToMultiByte(CP_UTF8, 0, wstr, -1, str, len, NULL, NULL); string strTemp = str; if (wstr) delete[] wstr; if (str) delete[] str; return strTemp; } ``` 此函数利用了Windows API中的`MultiByteToWideChar`和`WideCharToMultiByte`,将GBK编码的字符串转换为宽字符(Unicode),再转回UTF-8。 在C++调用Python的例子中: ```cpp const char* name = 东方红1号; Py_Initialize(); // 初始化Python环境 PyObject* pModule = PyImport_ImportModule(hello); PyObject* pFunc1 = PyObject_GetAttrString(pModule, sayhello); // 创建参数元组并设置GBK编码的字符串为UTF-8 PyObject* pArgs = PyTuple_New(1); PyObject* pV1 = Py_BuildValue(s, GbkToUtf8(name).c_str()); PyTuple_SetItem(pArgs, 0, pV1); // 调用Python函数 PyObject* result = PyObject_CallObject(pFunc1, pArgs); Py_Finalize(); return 0; ``` 这段代码首先初始化Python环境,然后导入名为hello的模块,并获取其中名为sayhello的函数。在创建参数元组时,我们使用`GbkToUtf8`将GBK编码字符串转换为UTF-8格式以确保Python能够正确解析中文字符。 总结来说,解决C++调用Python时出现的乱码问题的关键在于理解两种语言之间的编码差异,并保证数据传递过程中的适当编码转换。通过编写一个函数来处理GBK到UTF-8的转换,可以使C++成功地向Python发送包含中文字符的数据字符串。这种方法可以作为其他类似情形下的参考方案,但应注意到不同的环境和需求可能需要采用不同策略以达到相同目的。对于涉及其它编程语言与Python交互的情况同样要注意编码一致性问题,以免出现乱码现象。
  • SVN
    优质
    本文将详细介绍在使用SVN过程中遇到乱码问题的原因及解决方案,帮助开发者顺利解决编码困扰。 1. 将svn下的wc.db文件复制到软件目录; 2. 在命令行界面切换至该软件目录,并运行sqlite3命令; 3. 执行delete from work_queue以清除工作队列中的数据; 4. 用更新后的wc.db覆盖svn上的原始版本,之后进行clean up操作。