簡體   English   中英

從工作表中查找鏈接的公式值並替換為實際的單元格值

[英]Find linked formula values from worksheets and replace with actual cell value

在 OOXML 電子表格.xlsx 中,您可以通過鏈接公式從另一個電子表格中獲取值,並將它們作為值保存在您的工作表中,當另一個電子表格中的這些值更新時,這些值將始終更新。

I am using Open Xml SDK and I basically want to do what this does: https://www.e-iceblue.com/Tutorials/Spire.XLS/Spire.XLS-Program-Guide/Formula/Remove-Formulas-from-單元格但保留值在 Excel 中的 C.html

我如何能:

  • 查找具有將值鏈接到另一個電子表格中的單元格的公式的值
  • 將公式值替換為實際的單元格值
  • 在電子表格的每個工作表中執行此 foreach 單元格

到目前為止我已經嘗試過了: https://docs.microsoft.com/en-us/office/open-xml/how-to-retrieve-the-values-of-cells-in-a-spreadsheet

但是每次單元格不包含公式或任何值時,我都會收到NullRefereceneException 我試過 try-catch 和其他幾種方法來逃避這個異常,但它不起作用。

但回到上面概述的挑戰; 誰能幫我嗎?

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

這對我有用:

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);
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM