如何将多个工作表合并为具有样式的单个工作表

  • 本文关键字:工作 样式 单个 合并 c# excel
  • 更新时间 :
  • 英文 :


我知道,关于这个主题有很多问题,但我没有找到可用的解决方案。

我有多个excel文件,每个文件都有一个工作表,我想将工作表合并到一个工作簿和具有所有样式(列宽、单元格边框、填充颜色、字体大小等(的工作表中。

我怎么能做到呢,我试过Spire.Xls,但风格没有复制。

private void CombineFiles(List<string> files,string outputPath)
{
Spire.Xls.Workbook resultworkbook = new Spire.Xls.Workbook();
Spire.Xls.Worksheet resultworksheet = resultworkbook.Worksheets.Add("worksheet");
foreach (var file in files)
{
Spire.Xls.Workbook workbook = new Spire.Xls.Workbook();
workbook.LoadFromFile(file);
Spire.Xls.Worksheet sheet = workbook.Worksheets[0];
System.Data.DataTable dataTable = sheet.ExportDataTable();
resultworksheet.InsertDataTable(dataTable, false, sheet.LastRow + 1, 1);
}
resultworkbook.SaveToFile(outputPath);
System.Diagnostics.Process.Start(outputPath);
}

如果您想在将多个工作表合并到一个工作表时复制样式,您应该使用CellRange.copy((/worksheet.copy((而不是worksheet.InsertDataTable((。还要注意,不可能复制列宽,如果所有列宽都相同,您可以获得列宽,然后设置为复制的列。

尝试以下代码:

static void Main(string[] args)
{
string outputPath = "‪output.xlsx";
List<string> files = new List<string>();
files.Add(@"File1.xlsx");
files.Add(@"File2.xlsx");
CombineFiles(files, outputPath);
}
private static void CombineFiles(List<string> files, string outputPath)
{
Spire.Xls.Workbook resultworkbook = new Spire.Xls.Workbook();
resultworkbook.Worksheets.Clear();
Spire.Xls.Worksheet resultworksheet = resultworkbook.Worksheets.Add("worksheet");
Spire.Xls.Workbook workbook = new Spire.Xls.Workbook();
for (int i = 0; i < files.Count; i++)
{
workbook.LoadFromFile(files[i]);
Worksheet sheet = workbook.Worksheets[0];
if (i == 0)
{
sheet.AllocatedRange.Copy(resultworksheet.Range[1, 1], true, true);
}
else
{
sheet.AllocatedRange.Copy(resultworksheet.Range[resultworksheet.LastRow + 1, 1], true, true);
}
}

resultworkbook.SaveToFile(outputPath, ExcelVersion.Version2013);
System.Diagnostics.Process.Start(outputPath);
}

最新更新