c# - 打开 xml sdk 2.0 使用公式读取 excel 单元格值
问题描述
我正在使用 openXML sdk 读取 excel 文件。一些 excel 单元格包含公式,我想读取单元格的值,但是当我使用下面的代码时,它正在获取我的公式。如何获得价值。
WorksheetPart wsPart = (WorksheetPart)(wbPart.GetPartById(theSheet.Id));
using(SpreadsheetDocument document = SpreadsheetDocument.Open(fileName, false))
{
WorkbookPart wbPart = document.WorkbookPart;
Sheet theSheet = wbPart.Workbook.Descendants<Sheet>().Where(s => s.Name == sheetName).FirstOrDefault();
WorksheetPart wsPart = (WorksheetPart)(wbPart.GetPartById(theSheet.Id));
Cell theCell = wsPart.Worksheet.Descendants<Cell>().Where(c => c.CellReference == "D16").FirstOrDefault();
value = theCell.InnerText;
}
在这里,我正在阅读包含公式的特定单元格“D16”。
需要更多帮助,无法读取单元格的日期。我得到了一些数字。对于日期单元格数据类型为 Null,因此下面的代码不起作用。如何从单元格中获取日期值
if (theCell != null)
{
value = theCell.CellValue.InnerText;
if (theCell.DataType != null)
{
switch (theCell.DataType.Value)
{
case CellValues.SharedString:
var stringTable = wbPart.GetPartsOfType<SharedStringTablePart>().FirstOrDefault();
if (stringTable != null)
{
value = stringTable.SharedStringTable.ElementAt(int.Parse(value)).InnerText;
}
break;
case CellValues.Boolean:
switch (value)
{
case "0":
value = "FALSE";
break;
default:
value = "TRUE";
break;
}
break;
}
}
}
解决方案
尝试单元格的CellValue属性。
WorksheetPart wsPart = (WorksheetPart)(wbPart.GetPartById(theSheet.Id));
using(SpreadsheetDocument document = SpreadsheetDocument.Open(fileName, false))
{
WorkbookPart wbPart = document.WorkbookPart;
Sheet theSheet = wbPart.Workbook.Descendants<Sheet>().Where(s => s.Name == sheetName).FirstOrDefault();
WorksheetPart wsPart = (WorksheetPart)(wbPart.GetPartById(theSheet.Id));
Cell theCell = wsPart.Worksheet.Descendants<Cell>().Where(c => c.CellReference == "D16").FirstOrDefault();
value = theCell.CellValue;
}
我假设您正在对单元格引用进行硬编码以进行调试。否则我强烈建议不要这样做。
推荐阅读
- dialogflow-es - 我无法在 Dialogflow 的集成部分更改电报令牌。“机器人没有被阻止”
- angular - 如何让我的 Angular Web 应用在移动 Chrome 中全屏打开?
- java - Spring Boot Keycloak - 每个请求验证 3 次
- reactjs - 使用 Axios 和 React 从后端删除项目后无法更新状态
- networking - 我的 ONOS 控制器无法识别主机(Mininet 拓扑)
- css - 带有文字装饰的文字阴影
- spring - 如何在不更新现有实体的情况下创建新实体和现有实体之间的关系?
- neural-network - 从张量复制构造:用户警告
- java - 如何将图像设置为相机源
- python - 美汤中的进一步提炼清单