gpt4 book ai didi

c# - 如何使用 OpenXml 和 c# 从范围中获取所有行/单元格值

转载 作者:行者123 更新时间:2023-12-04 21:50:46 25 4
gpt4 key购买 nike

我正在使用带有 OpenXml 的 c# 来尝试从 Excel 工作簿中读取一些单元格值。

我有一些字符串来定义我需要提取的单元格的工作表和范围,例如,

'Master Products'!$Q$4:$AD$89"

我从 Workbookpart 实例中的 DefinedName 获取上述字符串。

如何使用 OpenXml 获取此范围内描述的单元格值?

最佳答案

您可以创建自定义方法来遍历范围并读取单元格值。我会这样做:

static void Main(string[] args)
{
int rowStart = 4;
string colStart = "Q";
int rowEnd = 89;
string colEnd = "AD";
string currentRow = colStart;
// make sure rowStart < rowEnd && colStart < colEnd

using (document = SpreadsheetDocument.Open(filePath, true))
{
WorkbookPart wbPart = document.WorkbookPart;
Worksheet sheet = wbPart.WorksheetParts.First().Worksheet;
while(currentRow != GetNextColumn(colEnd))
{
for (int i = rowStart; i <= rowEnd; i++)
{
Cell cell = GetCell(sheet, currentRow, i);
}
currentRow = GetNextColumn(currentRow);
}
}
Console.Read();
}

获取单元格值的方法:
private static Cell GetCell(Worksheet worksheet,
string columnName, uint rowIndex)
{
Row row = GetRow(worksheet, rowIndex);

if (row == null)
return null;

return row.Elements<Cell>().Where(c => string.Compare
(c.CellReference.Value, columnName +
rowIndex, true) == 0).First();
}

获取行的方法:
// Given a worksheet and a row index, return the row.
private static Row GetRow(Worksheet worksheet, uint rowIndex)
{
return worksheet.GetFirstChild<SheetData>().
Elements<Row>().Where(r => r.RowIndex == rowIndex).First();
}

获取下一列的方法:
static string GetNextColumn(string col)
{
char[] charArr = col.ToCharArray();
var cur = Convert.ToChar((int) charArr[charArr.Length - 1]);
if (cur == 'Z')
{
if (charArr.Length == 1)
{
return "AA";
}
else
{
char[] newArray = charArr.Take(charArr.Length - 1).ToArray();
var ret = GetNextColumn(new string(newArray));
return ret + "A";
}
}
charArr[charArr.Length - 1] = Convert.ToChar((int)charArr[charArr.Length - 1] + 1);
return new string(charArr);
}

关于c# - 如何使用 OpenXml 和 c# 从范围中获取所有行/单元格值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54483407/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com