Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/excel/28.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何使用C从数据集中创建包含多张工作表的excel文件#_Excel_C# 4.0_Dataset - Fatal编程技术网

如何使用C从数据集中创建包含多张工作表的excel文件#

如何使用C从数据集中创建包含多张工作表的excel文件#,excel,c#-4.0,dataset,Excel,C# 4.0,Dataset,如何使用C#从数据集创建包含多张图纸的excel文件。我已经成功地创建了一个excel文件,只有一张工作表。但我无法对多张纸进行此操作 问候 Harsh这里有一个简单的C#类,它通过编程创建一个Excel工作簿并向其中添加两张工作表,然后填充这两张工作表。最后,它将工作簿保存到应用程序根目录中的一个文件中,以便您可以检查结果 public class Tyburn1 { object missing = Type.Missing; public Tyburn1() {

如何使用C#从数据集创建包含多张图纸的excel文件。我已经成功地创建了一个excel文件,只有一张工作表。但我无法对多张纸进行此操作

问候 Harsh

这里有一个简单的C#类,它通过编程创建一个Excel工作簿并向其中添加两张工作表,然后填充这两张工作表。最后,它将工作簿保存到应用程序根目录中的一个文件中,以便您可以检查结果

public class Tyburn1
{
    object missing = Type.Missing;
    public Tyburn1()
    {
        Excel.Application oXL = new Excel.Application();
        oXL.Visible = false;
        Excel.Workbook oWB = oXL.Workbooks.Add(missing);
        Excel.Worksheet oSheet = oWB.ActiveSheet as Excel.Worksheet;
        oSheet.Name = "The first sheet";
        oSheet.Cells[1, 1] = "Something";
        Excel.Worksheet oSheet2 = oWB.Sheets.Add(missing, missing, 1, missing) 
                        as Excel.Worksheet;
        oSheet2.Name = "The second sheet";
        oSheet2.Cells[1, 1] = "Something completely different";
        string fileName = Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location)        
                                + "\\SoSample.xlsx";
        oWB.SaveAs(fileName, Excel.XlFileFormat.xlOpenXMLWorkbook,
            missing, missing, missing, missing,
            Excel.XlSaveAsAccessMode.xlNoChange,
            missing, missing, missing, missing, missing);
        oWB.Close(missing, missing, missing);
        oXL.UserControl = true;
        oXL.Quit();
    }
}
要执行此操作,您需要将对Microsoft.Office.Interop.Excel的引用添加到项目中(您可能已经这样做了,因为您正在创建一张工作表)

添加第二页的语句是

Excel.Worksheet oSheet2 = oWB.Sheets.Add(missing, missing, 1, missing) 
                            as Excel.Worksheet;
“1”参数指定一张工作表,如果要同时添加多张工作表,则可以使用更多参数

最后注意:语句oXL.Visible=false;告诉Excel以静默模式启动

var groupedSheetList = UserData
    .GroupBy (u => u.date)
    .Select (grp => grp.ToList ())
    .ToList ();
你可以试试这个

using (var package = new ExcelPackage ()) 
    {
        foreach (var item in groupedSheetList) {
            var workSheet = package.Workbook.Worksheets.Add (item[0].date);
    }
}

我想这取决于您如何创建excel文件。您是否正在为数据集中的每个表创建页面?您可能更改了默认的Excel行为。查看您正在为已创建的单张图纸使用哪种技术或组件?我在oXL.Quit()上遇到一个错误;每次都是。Excel Undantagskod:xc0000005 Felförskjutning:0x000000000000f993。错误会被放入计算机的事件日志中。你还需要C#4中缺失的arumgents吗?仅使用dynamic oWB=excelApplication.Workbooks.Add()还不够吗;