當前位置: 首頁>>代碼示例>>C#>>正文


C# HSSFWorkbook.WriteProtectWorkbook方法代碼示例

本文整理匯總了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);
        }
開發者ID:mdjasim,項目名稱:npoi,代碼行數:12,代碼來源:TestHSSFWorkbook.cs

示例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);
//.........這裏部分代碼省略.........
開發者ID:dada2cindy,項目名稱:my-case-petemobile,代碼行數:101,代碼來源:NPOIHelper.cs


注:本文中的NPOI.HSSF.UserModel.HSSFWorkbook.WriteProtectWorkbook方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。