我有一个要求将Excel(2010)文件转换为csv。目前我使用Excel Interop打开并保存CSV文件,效果很好。然而,Interop在我们使用它的环境中存在一些问题,所以我正在寻找另一种解决方案。如何使用OpenXML SDK将Excel转换为CSV?
我发现在没有互操作的情况下使用Excel文件的方式是使用OpenXML SDK。我将一些代码组合在一起以遍历每张表中的所有单元格,并简单地将它们写入另一个CSV文件中。
我遇到的一个问题是处理空白行和单元格。看来,用这段代码,空行和单元格完全不存在,所以我无法知道它们。是否有通过所有的行和单元格,包括空白?
string filename = @"D:\test.xlsx";
string outputDir = Path.GetDirectoryName(filename);
//--------------------------------------------------------
using (SpreadsheetDocument document = SpreadsheetDocument.Open(filename, false))
{
foreach (Sheet sheet in document.WorkbookPart.Workbook.Descendants<Sheet>())
{
WorksheetPart worksheetPart = (WorksheetPart) document.WorkbookPart.GetPartById(sheet.Id);
Worksheet worksheet = worksheetPart.Worksheet;
SharedStringTablePart shareStringPart = document.WorkbookPart.GetPartsOfType<SharedStringTablePart>().First();
SharedStringItem[] items = shareStringPart.SharedStringTable.Elements<SharedStringItem>().ToArray();
// Create a new filename and save this file out.
if (string.IsNullOrWhiteSpace(outputDir))
outputDir = Path.GetDirectoryName(filename);
string newFilename = string.Format("{0}_{1}.csv", Path.GetFileNameWithoutExtension(filename), sheet.Name);
newFilename = Path.Combine(outputDir, newFilename);
using (var outputFile = File.CreateText(newFilename))
{
foreach (var row in worksheet.Descendants<Row>())
{
StringBuilder sb = new StringBuilder();
foreach (Cell cell in row)
{
string value = string.Empty;
if (cell.CellValue != null)
{
// If the content of the first cell is stored as a shared string, get the text
// from the SharedStringTablePart. Otherwise, use the string value of the cell.
if (cell.DataType != null && cell.DataType.Value == CellValues.SharedString)
value = items[int.Parse(cell.CellValue.Text)].InnerText;
else
value = cell.CellValue.Text;
}
// to be safe, always use double quotes.
sb.Append(string.Format("\"{0}\",", value.Trim()));
}
outputFile.WriteLine(sb.ToString().TrimEnd(','));
}
}
}
}
如果我有下面的Excel文件数据:
one,two,three
,,
last,,row
我会得到下面的CSV(这是错误的):
one,two,three
last,row
不使用与OleDbConnection已安装需要的Excel? Open XML SDK的优点是不需要Excel。 –
不需要,不需要。它会将文件视为一个二进制数据存储,它就是这样。由于某种原因,我最终每两到三年就会这样做:)。 –
我还应该注意到,我做了很多OpenXML工作......这将是一个使用核弹杀死蚊子的情况。 –