国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

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

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

瀏覽:150日期: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
主站蜘蛛池模板: 仁化县| 尚志市| 垫江县| 江北区| 阿拉善右旗| 巴中市| 辛集市| 景德镇市| 剑川县| 保定市| 鄢陵县| 八宿县| 太原市| 抚顺县| 密云县| 大厂| 阳山县| 中山市| 彰化县| 静海县| 章丘市| 台东市| 阿拉善右旗| 巩义市| 镇雄县| 巧家县| 噶尔县| 伊金霍洛旗| 仁化县| 富平县| 彰化市| 赫章县| 武清区| 宣化县| 融水| 铁岭市| 区。| 西藏| 砀山县| 石家庄市| 武汉市|