久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

使用NPOI導出包含圖片數據的EXCEL文件打不開,幫忙看下代碼

瀏覽:136日期:2022-10-15 09:45:18

問題描述

要建立一個三列的excel表格,最后一列是個二維碼,使用NPOI寫完之后,導出的死活打不開,不知道代碼哪里錯了,麻煩各位幫忙看看代碼哪里錯了,不甚感激。

public static void CreateImageExcel(List<string> links){ //創建工作薄 HSSFWorkbook workbook = new HSSFWorkbook(); HSSFSheet sheet = (HSSFSheet)workbook.CreateSheet("Sheet1"); //填充列標題以及樣式 int rowsNum = 0; //行號 HSSFRow headerRow = (HSSFRow)sheet.CreateRow(rowsNum); string strQrCodePath = ""; headerRow.CreateCell(0, CellType.String).SetCellValue("編號"); headerRow.CreateCell(1, CellType.String).SetCellValue("鏈接"); headerRow.CreateCell(2, CellType.String).SetCellValue("二維碼"); HSSFRow row = null; rowsNum = 1; //行號,從第2行開始 foreach (var link in Links) {//寫入字段值 row = (HSSFRow)sheet.CreateRow(rowsNum);row.CreateCell(0, CellType.String).SetCellValue(rowsNum);row.CreateCell(1, CellType.String).SetCellValue(Link);row.CreateCell(2, CellType.Blank).SetCellValue("");strQrCodePath = CommonHelper.CreateQRCode(Configer.GetAppSetting<string>("siteUrl") + "/p/" + item.Link, 8, 4);byte[] bytes = System.IO.File.ReadAllBytes(strQrCodePath);int pictureIdx = workbook.AddPicture(bytes, PictureType.PNG);HSSFPatriarch patriarch = (HSSFPatriarch)sheet.CreateDrawingPatriarch();HSSFClientAnchor anchor = new HSSFClientAnchor(0, 10, 1023, 0, 2, rowsNum, 2, rowsNum);HSSFPicture pict = (HSSFPicture)patriarch.CreatePicture(anchor, pictureIdx);pict.Resize();rowsNum++;//刪除二維碼if (System.IO.File.Exists(strQrCodePath)){ System.IO.File.Delete(strQrCodePath);} } using (MemoryStream ms = new MemoryStream()) {workbook.Write(ms);ms.Flush();ms.Position = 0;// 設置編碼和附件格式 string fileName = model.Channel.Name + "_" + DateTime.Now.ToString("yyyy-MM-dd-HHmmss") + ".xlsx";//客戶端保存的文件名System.Web.HttpContext.Current.Response.ContentType = "application/vnd.ms-excel";System.Web.HttpContext.Current.Response.ContentEncoding = Encoding.UTF8;System.Web.HttpContext.Current.Response.Charset = "";System.Web.HttpContext.Current.Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(fileName, Encoding.UTF8));System.Web.HttpContext.Current.Response.BinaryWrite(ms.GetBuffer());ms.Close();ms.Dispose();System.Web.HttpContext.Current.Response.End(); }}

問題解答

回答1:

//創建工作薄 HSSFWorkbook workbook = new HSSFWorkbook(); 應該是這句代碼的問題HSSFWorkbook創建的工作簿只支持2003格式的,即xls要想導出xlsx的格式,應該用XSSFWorkbook對象,例如IWorkbook workbook = new XSSFWorkbook();我今天在做導入也遇到這個問題,通過上面的方式解決的

回答2:

改完了,只能導出.xls文件,不知道是不是其中有圖片的原因,導出的.xlsx文件無法查看。

標簽: excel
主站蜘蛛池模板: 资兴市| 奉新县| 彭水| 门源| 清河县| 博罗县| 丹寨县| 固始县| 东乡县| 高邑县| 河源市| 吐鲁番市| 瑞金市| 恭城| 赤壁市| 托里县| 南丰县| 咸丰县| 维西| 泰和县| 修文县| 霸州市| 牙克石市| 祁阳县| 修武县| 沈丘县| 清新县| 清镇市| 监利县| 抚州市| 海安县| 新民市| 呼伦贝尔市| 绥棱县| 滦平县| 常宁市| 东宁县| 华蓥市| 金华市| 迭部县| 昆山市|