excle,aspose.cells 公式字段值取不到 xmls转xml

问题:

一,单元格如果是公式的,读出值为0

aspose.cells 4.4.0.5版本 由于太低,读xmls后缀的excel文件时,发现如果此列是公式算出来的,值是获取不到的。获取到的值一直是0

二,升级可以解决问题。但会有如下问题

1,样式使用改动大

如果升级aspose,此问题可以解决。不过有好多地方要做修改。

2,转pdf打印有问题

如果你对aspose生成好的excle转pdf进行打印。会有断页,行自适应方法后,在excle显示正常,但打印出来后显示不全。

我试了。7.2.1.0版本5.3.1.0版本,版本越高打印越有问题。

三,解决。

直接用Microsoft.Office.Interop.Excel.dll 12.0版本就行了。这个东西在增加引用.net里就有。然后用我下面的代码将xmls转成xml就行了。原来的东西不用变

/// <summary>
        /// 转换Excel格式
        /// </summary>
        /// <param name="strSavePath">原始路径</param>
        /// <returns>新路径</returns>
        public static string ConvertExcel(string strSavePath)
        {
            string strPath = string.Empty;
            //将xml文件转换为标准的Excel格式 
            Object Nothing = System.Reflection.Missing.Value;//由于yongCOM组件很多值需要用Missing.Value代替   
            Excel.Application ExclApp = new Excel.ApplicationClass();// 初始化
            Excel.Workbook ExclDoc = ExclApp.Workbooks.Open(strSavePath, Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, Nothing);//打开Excl工作薄   
            FileInfo exportFile = new FileInfo(strSavePath);
            if (exportFile.Extension.Equals(".xlsx", StringComparison.OrdinalIgnoreCase))
            {
                strPath = exportFile.FullName.Replace(exportFile.Extension, ".xls");
                if (File.Exists(strPath))
                {
                    File.Delete(strPath);
                }
            }
            try
            {
                Object format = Excel.XlFileFormat.xlWorkbookNormal;//获取Excl 2007文件格式   这个不用管,就用这个,换成其他可能不行。
                ExclApp.DisplayAlerts = false;
                ExclDoc.SaveAs(strPath, format, Nothing, Nothing, Nothing, Nothing, Excel.XlSaveAsAccessMode.xlExclusive, Nothing, Nothing, Nothing, Nothing, Nothing);//保存为Excl 2007格式   
            }
            catch (Exception ex) { }
            ExclDoc.Close(Nothing, Nothing, Nothing);
            ExclApp.Quit();
            return strPath;
        }
转换Excel格式


 

 

转载于:https://www.cnblogs.com/xbding/p/4586883.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将Excel中的嵌入式图片公式换为图片并在前端展示,您可以使用以下步骤: 1. 使用`xlsx`库读取Excel文件并解析嵌入式图片的公式。 2. 将嵌入式图片的公式换为Base64格式的图片数据。 3. 使用HTML和CSS在前端展示换后的图片数据。 下面是一个示例代码,演示了如何实现上述步骤: ```html <!DOCTYPE html> <html> <head> <title>Embedded Image Display</title> <style> .image-container { display: flex; flex-wrap: wrap; } .image-container img { width: 200px; height: auto; margin: 10px; } </style> </head> <body> <input type="file" id="excelFile" accept=".xlsx, .xls" /> <div class="image-container" id="imageContainer"></div> <script src="https://unpkg.com/xlsx/dist/xlsx.full.min.js"></script> <script> document.getElementById("excelFile").addEventListener("change", handleFile, false); function handleFile(e) { var file = e.target.files[0]; var reader = new FileReader(); reader.onload = function (e) { var data = new Uint8Array(e.target.result); var workbook = XLSX.read(data, { type: "array" }); // 获取Excel第一个sheet的内容 var worksheet = workbook.Sheets[workbook.SheetNames[0]]; // 遍历单元格,查找嵌入式图片的公式 for (var cellAddress in worksheet) { if (!worksheet.hasOwnProperty(cellAddress)) continue; var cell = worksheet[cellAddress]; if (cell.d && cell.d.indexOf("DISPIMG") === 0) { // 提取嵌入式图片的公式 var formula = cell.d; // 使用正则表达式获取图片ID var imageId = formula.match(/\"(.*?)\"/)[1]; // 将嵌入式图片换为Base64格式的图片数据 var base64ImageData = workbook.Parts['/xl/media/image' + imageId + '.jpeg'].data; // 创建<img>元素,展示换后的图片数据 var imageContainer = document.getElementById("imageContainer"); var imgElement = document.createElement("img"); imgElement.src = "data:image/jpeg;base64," + base64ImageData; imageContainer.appendChild(imgElement); } } }; reader.readAsArrayBuffer(file); } </script> </body> </html> ``` 在这个示例中,我们使用`xlsx`库来读取Excel文件,并使用`<input type="file">`元素获取用户上传的文件。一旦文件上传完成,它将读取Excel文件的内容,并查找嵌入式图片的公式。然后,它将使用正则表达式提取出图片ID,并根据ID获取Base64格式的图片数据。最后,它将创建`<img>`元素,并将换后的图片数据赋给`src`属性,以在前端展示。 请注意,上述示例假设Excel中嵌入式图片的公式格式为`DISPIMG("ID")`,并且图片的实际数据在Excel文件的`xl/media`目录下。您可能需要根据您的实际情况进行相应的修改和调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值