ExcelExporter.cs 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. using System.Diagnostics;
  2. using InABox.Core;
  3. using Syncfusion.XlsIO;
  4. using MessageBox = System.Windows.MessageBox;
  5. using SaveFileDialog = Microsoft.Win32.SaveFileDialog;
  6. namespace InABox.WPF
  7. {
  8. public static class ExcelExporter
  9. {
  10. private static void ExportSheet(int i, IWorkbook workbook, Type? T, CoreTable data)
  11. {
  12. var sheet = workbook.Worksheets[i];
  13. sheet.Name = T?.EntityName().Split('.').Last() ?? data.TableName;
  14. for (var iCol = 0; iCol < data.Columns.Count; iCol++)
  15. {
  16. var field = data.Columns[iCol].ColumnName;
  17. var editor = T != null ? CoreUtils.GetProperty(T, field).GetEditor() : null;
  18. sheet.Range[1, iCol + 1].Text = field;
  19. for (var iRow = 0; iRow < data.Rows.Count; iRow++)
  20. {
  21. var val = data.Rows[iRow].Get<object>(field);
  22. if (editor is NotesEditor)
  23. sheet.Range[iRow + 2, iCol + 1].Text = string.Join("\n", val as string[]);
  24. else if (editor is RichTextEditor)
  25. sheet.Range[iRow + 2, iCol + 1].Text = CoreUtils.StripHTML(val as string);
  26. else
  27. sheet.Range[iRow + 2, iCol + 1].Value2 = val;
  28. }
  29. }
  30. sheet.UsedRange.AutofitColumns();
  31. foreach (var col in sheet.UsedRange.Columns)
  32. col.ColumnWidth += 5;
  33. foreach (var row in sheet.UsedRange.Rows)
  34. {
  35. row.RowHeight += 5;
  36. row.VerticalAlignment = ExcelVAlign.VAlignCenter;
  37. }
  38. }
  39. public static void DoExport(IEnumerable<Tuple<Type?, CoreTable>> data, string filename)
  40. {
  41. var excelEngine = new ExcelEngine();
  42. var application = excelEngine.Excel;
  43. var dataArr = data.ToArray();
  44. var myWorkbook = application.Workbooks.Create(dataArr.Length);
  45. myWorkbook.Version = ExcelVersion.Excel2007;
  46. int i = 0;
  47. foreach(var (tableType, table) in dataArr)
  48. {
  49. ExportSheet(i, myWorkbook, tableType, table);
  50. i++;
  51. }
  52. var dlg = new SaveFileDialog();
  53. dlg.Filter = "Excel Files (*.xlsx)|*.xlsx";
  54. dlg.InitialDirectory = Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments);
  55. dlg.FileName = string.Format("{0} {1:yyyy-MM-dd hh-mm-ss}.xlsx", CoreUtils.SanitiseFileName(filename), DateTime.Now);
  56. if (dlg.ShowDialog() == true)
  57. try
  58. {
  59. myWorkbook.SaveAs(dlg.FileName, ExcelSaveType.SaveAsXLS);
  60. Process.Start(new ProcessStartInfo(dlg.FileName) { UseShellExecute = true });
  61. }
  62. catch (Exception e2)
  63. {
  64. MessageBox.Show("Error saving spreadsheet!\n\n" + e2.Message);
  65. }
  66. }
  67. public static void DoExport<T>(CoreTable data, string filename)
  68. {
  69. DoExport(new[] { new Tuple<Type?, CoreTable>(typeof(T), data) }, filename);
  70. }
  71. public static void DoExport(CoreTable data, string filename)
  72. {
  73. DoExport(new[] { new Tuple<Type?, CoreTable>(null, data) }, filename);
  74. }
  75. }
  76. }