多表关联更新数据
sqlserver,oracle,mysql多表关联更新数据
序列化和反序列化会出现“k_BackingField”
序列化和反序列化会出现“k_BackingField”
DataGridView
自定义DataGridViewColumn(文本加图片、或下拉框等)
WebBrowser 打印
winform 使用webBrowser控件 打印,利用拼接字符串格式填充html标记 并添加javascript 函数 在后台程序中调用
zip压缩大全
zip压缩相关
1using System;
2using System.Collections.Generic;
3using System.Text;
4using System.IO;
5using ICSharpCode.SharpZipLib;
6using ICSharpCode.SharpZipLib.Zip;
7using ICSharpCode.SharpZipLib.Checksums;
8
9/*
10 * 解压缩
11 * 该程序压缩和解压配合才能使用
12 * 普通用 Winrar 压缩的文件该解压不能通过
13 * Modify By HJ 2007-10-25
14 */
15namespace ZipApplication
16{
17 ///
18 /// 压缩类
19 ///
20 public class ZipClass
21 {
22 ///
23 /// 递归压缩文件夹方法
24 ///
25 ///
26 ///
27 ///
28 private static bool ZipFileDictory(string FolderToZip, ZipOutputStream s, string ParentFolderName)
29 {
30 bool res = true;
31 string[] folders, filenames;
32 ZipEntry entry = null;
33 FileStream fs = null;
34 Crc32 crc = new Crc32();
35
36 try
37 {
38
39 //创建当前文件夹
40 entry = new ZipEntry(Path.Combine(ParentFolderName, Path.GetFileName(FolderToZip) + "/")); //加上 “/” 才会当成是文件夹创建
41 s.PutNextEntry(entry);
42 s.Flush();
43
44
45 //先压缩文件,再递归压缩文件夹
46 filenames = Directory.GetFiles(FolderToZip);
47 foreach (string file in filenames)
48 {
49 //打开压缩文件
50 fs = File.OpenRead(file);
51
52 byte[] buffer = new byte[fs.Length];
53 fs.Read(buffer, 0, buffer.Length);
54 entry = new ZipEntry(Path.Combine(ParentFolderName, Path.GetFileName(FolderToZip) + "/" + Path.GetFileName(file)));
55
56 entry.DateTime = DateTime.Now;
57 entry.Size = fs.Length;
58 fs.Close();
59
60 crc.Reset();
61 crc.Update(buffer);
62
63 entry.Crc = crc.Value;
64
65 s.PutNextEntry(entry);
66
67 s.Write(buffer, 0, buffer.Length);
68 }
69 }
70 catch
71 {
72 res = false;
73 }
74 finally
75 {
76 if (fs != null)
77 {
78 fs.Close();
79 fs = null;
80 }
81 if (entry != null)
82 {
83 entry = null;
84 }
85 GC.Collect();
86 GC.Collect(1);
87 }
88
89
90 folders = Directory.GetDirectories(FolderToZip);
91 foreach (string folder in folders)
92 {
93 if (!ZipFileDictory(folder, s, Path.Combine(ParentFolderName, Path.GetFileName(FolderToZip))))
94 {
95 return false;
96 }
97 }
98
99 return res;
100 }
101
102 ///
103 /// 压缩目录
104 ///
105 /// 待压缩的文件夹,全路径格式
106 /// 压缩后的文件名,全路径格式
107 ///
108 private static bool ZipFileDictory(string FolderToZip, string ZipedFile, String Password)
109 {
110 bool res;
111 if (!Directory.Exists(FolderToZip))
112 {
113 return false;
114 }
115
116 ZipOutputStream s = new ZipOutputStream(File.Create(ZipedFile));
117 s.SetLevel(6);
118 s.Password = Password;
119
120 res = ZipFileDictory(FolderToZip, s, "");
121
122 s.Finish();
123 s.Close();
124
125 return res;
126 }
127
128 ///
129 /// 压缩文件
130 ///
131 /// 要进行压缩的文件名
132 /// 压缩后生成的压缩文件名
133 ///
134 private static bool ZipFile(string FileToZip, string ZipedFile, String Password)
135 {
136 //如果文件没有找到,则报错
137 if (!File.Exists(FileToZip))
138 {
139 throw new System.IO.FileNotFoundException("指定要压缩的文件: " + FileToZip + " 不存在!");
140 }
141 //FileStream fs = null;
142 FileStream ZipFile = null;
143 ZipOutputStream ZipStream = null;
144 ZipEntry ZipEntry = null;
145
146 bool res = true;
147 try
148 {
149 ZipFile = File.OpenRead(FileToZip);
150 byte[] buffer = new byte[ZipFile.Length];
151 ZipFile.Read(buffer, 0, buffer.Length);
152 ZipFile.Close();
153
154 ZipFile = File.Create(ZipedFile);
155 ZipStream = new ZipOutputStream(ZipFile);
156 ZipStream.Password = Password;
157 ZipEntry = new ZipEntry(Path.GetFileName(FileToZip));
158 ZipStream.PutNextEntry(ZipEntry);
159 ZipStream.SetLevel(6);
160
161 ZipStream.Write(buffer, 0, buffer.Length);
162 }
163 catch
164 {
165 res = false;
166 }
167 finally
168 {
169 if (ZipEntry != null)
170 {
171 ZipEntry = null;
172 }
173 if (ZipStream != null)
174 {
175 ZipStream.Finish();
176 ZipStream.Close();
177 }
178 if (ZipFile != null)
179 {
180 ZipFile.Close();
181 ZipFile = null;
182 }
183 GC.Collect();
184 GC.Collect(1);
185 }
186
187 return res;
188 }
189
190 ///
191 /// 压缩文件 和 文件夹
192 ///
193 /// 待压缩的文件或文件夹,全路径格式
194 /// 压缩后生成的压缩文件名,全路径格式
195 ///
196 public static bool Zip(String FileToZip, String ZipedFile, String Password)
197 {
198 if (Directory.Exists(FileToZip))
199 {
200 return ZipFileDictory(FileToZip, ZipedFile, Password);
201 }
202 else if (File.Exists(FileToZip))
203 {
204 return ZipFile(FileToZip, ZipedFile, Password);
205 }
206 else
207 {
208 return false;
209 }
210 }
211 }
212
///
/// 解压类
///
public class UnZipClass
{
///
/// 解压功能(解压压缩文件到指定目录)
///
/// 待解压的文件
/// 指定解压目标目录
public static void UnZip(string FileToUpZip, string ZipedFolder,string Password)
{
if (!File.Exists(FileToUpZip))
{
return;
}
if (!Directory.Exists(ZipedFolder))
{
Directory.CreateDirectory(ZipedFolder);
}
ZipInputStream s = null;
ZipEntry theEntry = null;
string fileName;
FileStream streamWriter = null;
try
{
s = new ZipInputStream(File.OpenRead(FileToUpZip));
s.Password = Password;
while ((theEntry = s.GetNextEntry()) != null)
{
if (theEntry.Name != String.Empty)
{
fileName = Path.Combine(ZipedFolder, theEntry.Name);
///判断文件路径是否是文件夹
if (fileName.EndsWith("/") || fileName.EndsWith("\\"))
{
Directory.CreateDirectory(fileName);
continue;
}
streamWriter = File.Create(fileName);
int size = 2048;
byte[] data = new byte[2048];
while (true)
{
size = s.Read(data, 0, data.Length);
if (size > 0)
{
streamWriter.Write(data, 0, size);
}
else
{
break;
}
}
}
}
}
finally
{
if (streamWriter != null)
{
streamWriter.Close();
streamWriter = null;
}
if (theEntry != null)
{
theEntry = null;
}
if (s != null)
{
s.Close();
s = null;
}
GC.Collect();
GC.Collect(1);
}
}
}
}
c# 操作Excel单元格属性
range.NumberFormatLocal = "@"; //设置单元格格式为文本
range = (Range)worksheet.get_Range("A1", "E1"); //获取Excel多个单元格区域:本例做为Excel表头
range.Merge(0); //单元格合并动作
worksheet.Cells[1, 1] = "Excel单元格赋值"; //Excel单元格赋值
range.Font.Size = 15; //设置字体大小
range.Font.Underline=true; //设置字体是否有下划线
range.Font.Name="黑体"; 设置字体的种类
range.HorizontalAlignment=XlHAlign.xlHAlignCenter; //设置字体在单元格内的对其方式
range.ColumnWidth=15; //设置单元格的宽度
range.Cells.Interior.Color=System.Drawing.Color.FromArgb(255,204,153).ToArgb(); //设置单元格的背景色
range.Borders.LineStyle=1; //设置单元格边框的粗细
range.BorderAround(XlLineStyle.xlContinuous,XlBorderWeight.xlThick,XlColorIndex.xlColorIndexAutomatic,System.Drawing.Color.Black.ToArgb()); //给单元格加边框
range.Borders.get_Item(Microsoft.Office.Interop.Excel.XlBordersIndex.xlEdgeTop).LineStyle = Microsoft.Office.Interop.Excel.XlLineStyle.xlLineStyleNone; //设置单元格上边框为无边框
range.EntireColumn.AutoFit(); //自动调整列宽
Range.HorizontalAlignment= xlCenter; // 文本水平居中方式
Range.VerticalAlignment= xlCenter //文本垂直居中方式
Range.WrapText=true; //文本自动换行
Range.Interior.ColorIndex=39; //填充颜色为淡紫色
Range.Font.Color=clBlue; //字体颜色
xlsApp.DisplayAlerts=false; //保存Excel的时候,不弹出是否保存的窗口直接进行保存
====================================================================
using System;
using System.Collections.Generic;
using System.Text;
using System.Reflection;
using System.Runtime.InteropServices;
using Microsoft.Office.Interop.Excel;
using ExcelApplication = Microsoft.Office.Interop.Excel.ApplicationClass;
using System.IO;
namespace ExcalDemo
{
public class ExcelFiles
{
public void CreateExcelFiles()
{
ExcelApplication excel = new ExcelApplication();
try
{
excel.Visible = false;// 不显示 Excel 文件,如果为 true 则显示 Excel 文件
excel.Workbooks.Add(Missing.Value);// 添加工作簿
Worksheet sheet = (Worksheet)excel.ActiveSheet;// 获取当前工作表
Range range = null;// 创建一个空的单元格对象
range = sheet.get_Range("A1", Missing.Value);// 获取单个单元格
range.RowHeight = 20; // 设置行高
range.ColumnWidth = 20; // 设置列宽
range.Borders.LineStyle = 1; // 设置单元格边框
range.Font.Bold = true; // 加粗字体
range.Font.Size = 20; // 设置字体大小
range.Font.ColorIndex = 5; // 设置字体颜色
range.Interior.ColorIndex = 6; // 设置单元格背景色
range.HorizontalAlignment = XlHAlign.xlHAlignCenter;// 设置单元格水平居中
range.VerticalAlignment = XlVAlign.xlVAlignCenter;// 设置单元格垂直居中
range.Value2 = "设置行高和列宽";// 设置单元格的值
range = sheet.get_Range("B2", "D4");// 获取多个单元格
range.Merge(Missing.Value); // 合并单元格
range.Columns.AutoFit(); // 设置列宽为自动适应
range.NumberFormatLocal = "#,##0.00";// 设置单元格格式为货币格式
// 设置单元格左边框加粗
range.Borders[XlBordersIndex.xlEdgeLeft].Weight = XlBorderWeight.xlThick;
// 设置单元格右边框加粗
range.Borders[XlBordersIndex.xlEdgeRight].Weight = XlBorderWeight.xlThick;
range.Value2 = "合并单元格";
// 页面设置
sheet.PageSetup.PaperSize = XlPaperSize.xlPaperA4; // 设置页面大小为A4
sheet.PageSetup.Orientation = XlPageOrientation.xlPortrait; // 设置垂直版面
sheet.PageSetup.HeaderMargin = 0.0; // 设置页眉边距
sheet.PageSetup.FooterMargin = 0.0; // 设置页脚边距
sheet.PageSetup.LeftMargin = excel.InchesToPoints(0.354330708661417); // 设置左边距
sheet.PageSetup.RightMargin = excel.InchesToPoints(0.354330708661417);// 设置右边距
sheet.PageSetup.TopMargin = excel.InchesToPoints(0.393700787401575); // 设置上边距
sheet.PageSetup.BottomMargin = excel.InchesToPoints(0.393700787401575);// 设置下边距
sheet.PageSetup.CenterHorizontally = true; // 设置水平居中
// 打印文件
sheet.PrintOut(Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);
// 保存文件到程序运行目录下
sheet.SaveAs(Path.Combine(System.Windows.Forms.Application.StartupPath,"demo.xls"), Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);
excel.ActiveWorkbook.Close(false, null, null); // 关闭 Excel 文件且不保存
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
excel.Quit(); // 退出 Excel
excel = null; // 将 Excel 实例设置为空
}
}
}
}
CodeSmith6.5
codesmith6.5.0破解版本不包含注册机