C#을 이용하여 DataSet에서 여러 장의 시트로 엑셀파일을 만드는 방법
C#을 이용하여 DataSet에서 여러 장의 시트로 엑셀파일을 만드는 방법은?
저는 싱글시트로 엑셀파일을 성공적으로 작성하였습니다.하지만 여러 장에 걸쳐 그렇게 할 수는 없습니다.
Excel WorkBook을 프로그램적으로 생성하고 여기에 두 장을 추가한 다음 두 장을 채우는 간단한 C# 클래스가 있습니다.마지막으로 워크북을 응용프로그램 루트 디렉터리의 파일에 저장하여 결과를 검사할 수 있습니다.
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에 대한 참조를 추가해야 합니다.사무실.인터럽트.프로젝트를 수행합니다(한 장을 생성하는 중이므로 이미 이 작업을 수행했을 수 있습니다).
두번째 시트를 추가하는 문장은...
Excel.Worksheet oSheet2 = oWB.Sheets.Add(missing, missing, 1, missing)
as Excel.Worksheet;
'1' 인수는 단일 시트를 지정하며, 여러 시트를 한 번에 추가하려면 더 많을 수 있습니다.
마지막 노트: osl문입니다.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);
}
}
언급URL : https://stackoverflow.com/questions/8156616/how-to-create-excel-file-with-multiple-sheets-from-dataset-using-c-sharp
'programing' 카테고리의 다른 글
PHP에서 다운로드할 파일을 생성한 후 리디렉션 (0) | 2023.09.16 |
---|---|
GCC: 상수 변수가 .rodata에 없는 이유 (0) | 2023.09.16 |
변수의 값을 다른 값으로 복사 (0) | 2023.09.11 |
GitHub: 이전 버전의 파일 검색 (0) | 2023.09.11 |
파이썬에서 파일을 한 줄씩 읽으려면 어떻게 해야 합니까? (0) | 2023.09.11 |