本文整理匯總了C#中NPOI.HSSF.UserModel.HSSFWorkbook.WriteProtectWorkbook方法的典型用法代碼示例。如果您正苦於以下問題:C# HSSFWorkbook.WriteProtectWorkbook方法的具體用法?C# HSSFWorkbook.WriteProtectWorkbook怎麽用?C# HSSFWorkbook.WriteProtectWorkbook使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類NPOI.HSSF.UserModel.HSSFWorkbook
的用法示例。
在下文中一共展示了HSSFWorkbook.WriteProtectWorkbook方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: TestWriteProtection
public void TestWriteProtection()
{
HSSFWorkbook wb = new HSSFWorkbook();
Assert.IsFalse(wb.IsWriteProtected);
wb.WriteProtectWorkbook("mypassword", "myuser");
Assert.IsTrue(wb.IsWriteProtected);
wb.UnwriteProtectWorkbook();
Assert.IsFalse(wb.IsWriteProtected);
}
示例2: Export
/// <summary>
/// DataTable導出到Excel的MemoryStream 第二步
/// </summary>
/// <param name="dtSource">源DataTable</param>
/// <param name="strHeaderText">表頭文本</param>
public static MemoryStream Export(DataTable dtSource, string strHeaderText, bool usePassword, string path)
{
SystemFactory systemFactory = new SystemFactory();
ISystemService systemService = systemFactory.GetSystemService();
SystemParamVO systemParamVO = systemService.GetSystemParamByRoot();
if (string.IsNullOrEmpty(path))
{
path = @"D:\temp.xls";
}
if (File.Exists(path))
{
File.Delete(path);
}
HSSFWorkbook fakeWorkbook = new HSSFWorkbook();
HSSFSheet fakeSheet = fakeWorkbook.CreateSheet() as HSSFSheet;
FileStream savefile = new FileStream(path, FileMode.Create);
fakeWorkbook.Write(savefile);
savefile.Close();
savefile.Dispose();
FileStream file = new FileStream(path, FileMode.Open, FileAccess.Read);
if (usePassword && systemParamVO!=null && !string.IsNullOrEmpty(systemParamVO.FilePassword))
{
NPOI.HSSF.Record.Crypto.Biff8EncryptionKey.CurrentUserPassword = "12345";//打開前調用
}
HSSFWorkbook workbook = new HSSFWorkbook(file);
if (usePassword && systemParamVO != null && !string.IsNullOrEmpty(systemParamVO.FilePassword))
{
workbook.WriteProtectWorkbook(systemParamVO.FilePassword, "");//設置新密碼
}
file.Close();
HSSFSheet sheet = (HSSFSheet)workbook.GetSheetAt(0);
#region 右擊文件 屬性信息
{
DocumentSummaryInformation dsi = PropertySetFactory.CreateDocumentSummaryInformation();
dsi.Company = "NPOI";
workbook.DocumentSummaryInformation = dsi;
SummaryInformation si = PropertySetFactory.CreateSummaryInformation();
si.Author = "文件作者信息"; //填加xls文件作者信息
si.ApplicationName = "創建程序信息"; //填加xls文件創建程序信息
si.LastAuthor = "最後保存者信息"; //填加xls文件最後保存者信息
si.Comments = "作者信息"; //填加xls文件作者信息
si.Title = "標題信息"; //填加xls文件標題信息
si.Subject = "主題信息";//填加文件主題信息
si.CreateDateTime = DateTime.Now;
workbook.SummaryInformation = si;
}
#endregion
HSSFCellStyle dateStyle = workbook.CreateCellStyle() as HSSFCellStyle;
HSSFDataFormat format = workbook.CreateDataFormat() as HSSFDataFormat;
dateStyle.DataFormat = format.GetFormat("yyyy-mm-dd");
//取得列寬
int[] arrColWidth = new int[dtSource.Columns.Count];
foreach (DataColumn item in dtSource.Columns)
{
arrColWidth[item.Ordinal] = Encoding.GetEncoding(936).GetBytes(item.ColumnName.ToString()).Length;
}
for (int i = 0; i < dtSource.Rows.Count; i++)
{
for (int j = 0; j < dtSource.Columns.Count; j++)
{
int intTemp = Encoding.GetEncoding(936).GetBytes(dtSource.Rows[i][j].ToString()).Length;
if (intTemp > arrColWidth[j])
{
arrColWidth[j] = intTemp;
}
}
}
int rowIndex = 0;
foreach (DataRow row in dtSource.Rows)
{
#region 新建表,填充表頭,填充列頭,樣式
if (rowIndex == 65535 || rowIndex == 0)
{
if (rowIndex != 0)
{
sheet = workbook.CreateSheet() as HSSFSheet;
}
#region 表頭及樣式
{
if (string.IsNullOrEmpty(strHeaderText))
{
HSSFRow headerRow = sheet.CreateRow(0) as HSSFRow;
headerRow.HeightInPoints = 25;
headerRow.CreateCell(0).SetCellValue(strHeaderText);
//.........這裏部分代碼省略.........