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

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

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

瀏覽:131日期: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
主站蜘蛛池模板: 广饶县| 扶沟县| 高密市| 阳高县| 耒阳市| 彭州市| 简阳市| 青河县| 健康| 鄂温| 望城县| 逊克县| 昭苏县| 临沭县| 厦门市| 星座| 堆龙德庆县| 赫章县| 蓬莱市| 县级市| 湟源县| 永年县| 梁平县| 山阳县| 宁安市| 县级市| 洛浦县| 绍兴市| 望城县| 钟祥市| 武威市| 呼图壁县| 兴城市| 芮城县| 商南县| 盐池县| 禄丰县| 威信县| 钟山县| 井冈山市| 汉中市|