社区
C#
帖子详情
压所Excel问题
zzyhuian06142
2007-07-06 05:27:06
哪位牛人会用C#来写个程序,主要实现把特定的Excel压缩成.ZIP或者.RAR文件啊
最好还能在压缩的时候设置解压缩的密码
可以实现吗?
...全文
169
7
打赏
收藏
压所Excel问题
哪位牛人会用C#来写个程序,主要实现把特定的Excel压缩成.ZIP或者.RAR文件啊 最好还能在压缩的时候设置解压缩的密码 可以实现吗?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
7 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
zzyhuian06142
2007-07-12
打赏
举报
回复
还没是看到好的解决办法,没办法了,只能用最笨的办法,直接给EXCEL设置密码了,谢谢大家了
marvelstack
2007-07-10
打赏
举报
回复
Compress Zip files with Windows Shell API and C#
http://www.codeproject.com/csharp/CompressWithWinShellAPICS.asp
通过 C# 使用 J# 类库中的 Zip 类压缩文件和数据
http://www.microsoft.com/china/msdn/library/langtool/vcsharp/miszipcompression.mspx
在.net 2.0中直接提供相关类,
System.IO.Compression 命名空间包含提供基本的流压缩和解压缩服务的类。
marvelstack
2007-07-10
打赏
举报
回复
使用ICSharpCode.SharpZipLib.dll;
下载地址
http://www.icsharpcode.net/OpenSource/SharpZipLib/Download.aspx
下面是对#ZipLib进行.net下的解压缩的方法的介绍。
1.BZip2
加入ICSharpCode.SharpZipLib.dll的引用,在#Develop的安装目录下的\SharpDevelop\bin目录下。然后在程序中使用using语句把BZip2
类库包含进来。
压缩:使用BZip2的静态方法Compress。
它的第一个参数是所要压缩的文件所代表的输入流,可以使用System.IO.File的静态方法OpenRead。
第二个参数是要建立的压缩文件所代表的输出流,可以使用System.IO.File的静态方法Create创建,压缩文件名是所要压缩文件的文件名
加上压缩后缀.bz(同样你也可以取其他的文件名)。
第三个参数是要压缩的块大小(一般为2048的整数)。
解压:使用BZip2的静态方法Decompress。
它的第一个参数是所要解压的压缩文件所代表的输入流,可以使用System.IO.File的静态方法OpenRead。
第二个参数是要建立的解压文件所代表的输出流,可以使用System.IO.File的静态方法Create创建,因为解压文件的文件名是去掉了压缩
文件扩展名的压缩文件名(你也可以做成解压文件与压缩文件不同名的)。
编译你的程序,然后在命令行方式下输入bzip2 文件名(假设建立的C#文件是bzip2,就可以生成压缩文件;输入bzip2 -d 文件名,就会解压
出文件来(-d是用来表示解压,你也可以使用其他的符号)。
呵呵,原来做压缩可以这么简单的,压缩效果也可以啊。
using System;
using System.IO;
using ICSharpCode.SharpZipLib.BZip2;
class MainClass
{
public static void Main(string[] args)
{
if (args[0] == "-d") { // 解压
BZip2.Decompress(File.OpenRead(args[1]), File.Create(Path.GetFileNameWithoutExtension(args[1])));
} else { //压缩
BZip2.Compress(File.OpenRead(args[0]), File.Create(args[0] + ".bz"), 4096);
}
}
}
2.GZip
加入ICSharpCode.SharpZipLib.dll的引用,在#Develop的安装目录下的\SharpDevelop\bin目录下。然后在程序中使用using语句把GZip类
库包含进来。
由于GZip没有BZip2的简单解压缩方法,因此只能使用流方法来进行解压缩。具体的方法见程序的说明。
编译程序,然后在命令行方式下输入GZip 文件名(假设建立的C#文件是GZip,就可以生成压缩文件;输入GZip -d 文件名,就会解压出文
件来(-d是用来表示解压,你也可以使用其他的符号)。
using System;
using System.IO;
using ICSharpCode.SharpZipLib.GZip;
class MainClass
{
public static void Main(string[] args)
{
if (args[0] == "-d") { // 解压
Stream s = new GZipInputStream(File.OpenRead(args[1]));
//生成一个GZipInputStream流,用来打开压缩文件。
//因为GZipInputStream由Stream派生,所以它可以赋给Stream。
//它的构造函数的参数是一个表示要解压的压缩文件所代表的文件流
FileStream fs = File.Create(Path.GetFileNameWithoutExtension(args[1]));
//生成一个文件流,它用来生成解压文件
//可以使用System.IO.File的静态函数Create来生成文件流
int size = 2048;//指定压缩块的大小,一般为2048的倍数
byte[] writeData = new byte[size];//指定缓冲区的大小
while (true) {
size = s.Read(writeData, 0, size);//读入一个压缩块
if (size > 0) {
fs.Write(writeData, 0, size);//写入解压文件代表的文件流
} else {
break;//若读到压缩文件尾,则结束
}
}
s.Close();
} else { // 压缩
Stream s = new GZipOutputStream(File.Create(args[0] + ".gz"));
//生成一个GZipOutputStream流,用来生成压缩文件。
//因为GZipOutputStream由Stream派生,所以它可以赋给Stream。
FileStream fs = File.OpenRead(args[0]);
/生成一个文件流,它用来打开要压缩的文件
//可以使用System.IO.File的静态函数OpenRead来生成文件流
byte[] writeData = new byte[fs.Length];
//指定缓冲区的大小
fs.Read(writeData, 0, (int)fs.Length);
//读入文件
s.Write(writeData, 0, writeData.Length);
//写入压缩文件
s.Close();
//关闭文件
}
}
}
vainnetwork
2007-07-06
打赏
举报
回复
顶.C#可以调用压缩工具压缩的
lbq1221119
2007-07-06
打赏
举报
回复
dos 下面可以支持压缩么?
我记得codeproject上面看到过一个类可以压缩文件
cancerser
2007-07-06
打赏
举报
回复
zip在2.0以后 .net就直接支持了吧
1.0也是开源的搜下ICSharpCode.SharpZipLib 一堆堆的
RAR 这个压缩是收费的 就别想了,要是有钱买不如叫它公司给你写个 你调
lovingkiss
2007-07-06
打赏
举报
回复
Rar提供该功能的,甚至你都可以用DOS模式压缩下来的;
==================================================================
博客空间:http://blog.csdn.net/lovingkiss
资源下载:http://download.csdn.net/user/lovingkiss
Email:loving-kiss@163.com
本人说明:<我的帖子我做主,结贴率保持100%>
优惠接单开发,信誉保证,Q64180940(请清楚注明业务还是技术咨询)
==================================================================
MATLAB与
Excel
接口
介绍MATLAB与
Excel
接口的方法,包括MATLAB与
Excel
相互调用,以及将MATLAB代码打包成
Excel
插件并在
Excel
的VBA编程环境中使用的方法。 所在套餐:MATLAB核心知识点系列课程-CSDN程序员研修院,不断更新和增加课程。
Excel
分压电阻计算
Excel
对象应用
Excel
VBA代码 Private Sub Worksheet_SelectionChange(ByVal Target As Range) Dim i, j, k As Integer Dim RcountStar, RcountEnd, RcountStep As Integer Dim fVref, fVout, fAccur As Single ...
Jmeter(五)
excel
文件上传接口压力测试
问题
本章内容的话也是在公司中遇到的一个
问题
,需要对批量文件上传接口进行压测但是始终接口调不通报400的情况,终于找到了
问题
所在并予以解决 一、接口配置条件展示 配置好需要的组件(按个人需要去配置) --> 信息...
如何用
Excel
/WPS查询计算不同温度和压力下饱和蒸汽、过热蒸汽的焓值
本插件基于
Excel
DNA开发,可以实现在
Excel
/WPS查询计算不同温度和压力下饱和蒸汽、过热蒸汽的焓值、潜热等。
【
Excel
导入】关于
Excel
导入数据超时的一个小
问题
Excel
导入是运营批量任务常用的方法之一,但是代码在识别
Excel
的时候,获取方式不正确,或者
Excel
设置有
问题
的话,就会造成大量无用的处理请求,耽误代码执行的效率,例如:代码识别的时候,连同
Excel
的空白行都识别...
C#
110,534
社区成员
642,575
社区内容
发帖
与我相关
我的任务
C#
.NET技术 C#
复制链接
扫一扫
分享
社区描述
.NET技术 C#
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
让您成为最强悍的C#开发者
试试用AI创作助手写篇文章吧
+ 用AI写文章