首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从工作表中查找链接公式值,并用实际单元格值替换。

从工作表中查找链接公式值,并用实际单元格值替换。
EN

Stack Overflow用户
提问于 2022-08-04 10:05:40
回答 1查看 22关注 0票数 0

在OOXML电子表格中,您可以通过链接公式从另一个电子表格中获取值,并将它们作为值放在工作表中,在更新另一个电子表格中的值时总是会更新这些值。

我使用的是Open,基本上我想这样做:https://www.e-iceblue.com/Tutorials/Spire.XLS/Spire.XLS-Program-Guide/Formula/Remove-Formulas-from-Cells-but-Keep-Values-in-Excel-in-C.html

我如何:

在另一个spreadsheet

  • Replace中找到一个具有公式链接值的值的
  • ,公式值与实际单元格值
  • 在电子表格

中的每个工作表中执行此预测单元格。

到目前为止,我已经尝试过了:https://learn.microsoft.com/en-us/office/open-xml/how-to-retrieve-the-values-of-cells-in-a-spreadsheet

但是,每次单元格不包含公式或任何值时,我都会收到一个NullRefereceneException。我尝试过尝试-捕捉和其他几种方法来避免这个异常,但它不起作用。

但回到上面概述的挑战,有人能帮我吗?

基本的东西,如using SOME DIRECTIVEforeach loopOpen()Save(),我知道该怎么做。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-09-05 15:46:10

这对我起了作用:

代码语言:javascript
运行
复制
public void Remove_CellReferences(string filepath)
{
    using (SpreadsheetDocument spreadsheet = SpreadsheetDocument.Open(filepath, true))
    {
        // Delete all cell references in worksheet
        List<WorksheetPart> worksheetparts = spreadsheet.WorkbookPart.WorksheetParts.ToList();
        foreach (WorksheetPart part in worksheetparts)
        {
            Worksheet worksheet = part.Worksheet;
            var rows = worksheet.GetFirstChild<SheetData>().Elements<Row>(); // Find all rows
            foreach (var row in rows)
            {
                var cells = row.Elements<Cell>();
                foreach (Cell cell in cells)
                {
                    if (cell.CellFormula != null)
                    {
                        string formula = cell.CellFormula.InnerText;
                        if (formula.Length > 0)
                        {
                            string hit = formula.Substring(0, 1); // Transfer first 1 characters to string
                            if (hit == "[")
                            {
                                CellValue cellvalue = cell.CellValue; // Save current cell value
                                cell.CellFormula = null; // Remove RTD formula
                                                         // If cellvalue does not have a real value
                                if (cellvalue.Text == "#N/A")
                                {
                                    cell.DataType = CellValues.String;
                                    cell.CellValue = new CellValue("Invalid data removed");
                                }
                                else
                                {
                                    cell.CellValue = cellvalue; // Insert saved cell value
                                }
                            }
                        }
                    }
                }
            }
        }
        // Delete all external link references
        List<ExternalWorkbookPart> extwbParts = spreadsheet.WorkbookPart.ExternalWorkbookParts.ToList();
        if (extwbParts.Count > 0)
        {
            foreach (ExternalWorkbookPart extpart in extwbParts)
            {
                var elements = extpart.ExternalLink.ChildElements.ToList();
                foreach (var element in elements)
                {
                    if (element.LocalName == "externalBook")
                    {
                        spreadsheet.WorkbookPart.DeletePart(extpart);
                    }
                }
            }
        }
        // Delete calculation chain
        CalculationChainPart calc = spreadsheet.WorkbookPart.CalculationChainPart;
        spreadsheet.WorkbookPart.DeletePart(calc);
    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73234007

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档