WINFORM - DevExpress -> gridcontrol导出Excel通用方法

1.通用方法

/// <summary>
/// DevExpress通用导出Excel,支持多个控件同时导出在同一个Sheet表
/// eg:ExportToXlsx("",gridControl1,gridControl2);
/// 将gridControl1和gridControl2的数据一同导出到同一张工作表
/// </summary>
/// <param name="title">文件名</param>
/// <param name="panels">控件集</param>
public void ExportToExcel(string title, params IPrintable[] panels)
{
   SaveFileDialog saveFileDialog = new SaveFileDialog();
   saveFileDialog.FileName = title;
   saveFileDialog.Title = "导出Excel";
   saveFileDialog.Filter = "Excel文件(*.xlsx)|*.xlsx|Excel文件(*.xls)|*.xls";
   DialogResult dialogResult = saveFileDialog.ShowDialog();
   if (dialogResult == DialogResult.Cancel)
      return;
   string FileName = saveFileDialog.FileName;
   PrintingSystem ps = new PrintingSystem();
   CompositeLink link = new CompositeLink(ps);
   ps.Links.Add(link);
   foreach (IPrintable panel in panels)
   {
      link.Links.Add(CreatePrintableLink(panel));
   }
   link.Landscape = true;//横向          
   //判断是否有标题,有则设置        
   //link.CreateDocument(); //建立文档
   try
   {
     int count = 1;
     //在重复名称后加(序号)
     while (File.Exists(FileName))
     {
         if (FileName.Contains(")."))
         {
            int start = FileName.LastIndexOf("(");
            int end = FileName.LastIndexOf(").") - FileName.LastIndexOf("(") + 2;
            FileName = FileName.Replace(FileName.Substring(start, end), string.Format("({0}).", count));
         }
         else
         {
             FileName = FileName.Replace(".", string.Format("({0}).", count));
         }
         count++;
      }
      if (FileName.LastIndexOf(".xlsx") >= FileName.Length - 5)
      {
          XlsxExportOptions options = new XlsxExportOptions();
          link.ExportToXlsx(FileName, options);
      }
      else
      {
          XlsExportOptions options = new XlsExportOptions();
          link.ExportToXls(FileName, options);
      }
      if (DevExpress.XtraEditors.XtraMessageBox.Show("保存成功,是否打开文件?", "提示", MessageBoxButtons.YesNo, MessageBoxIcon.Information) == DialogResult.Yes)
          System.Diagnostics.Process.Start(FileName);//打开指定路径下的文件
      }
   catch (Exception ex)
   {
      DevExpress.XtraEditors.XtraMessageBox.Show(ex.Message);
   }
}
/// <summary>
/// 创建打印Componet
/// </summary>
/// <param name="printable"></param>
/// <returns></returns>
PrintableComponentLink CreatePrintableLink(IPrintable printable)
{
   ChartControl chart = printable as ChartControl;
   if (chart != null)
      chart.OptionsPrint.SizeMode = DevExpress.XtraCharts.Printing.PrintSizeMode.Stretch;
      PrintableComponentLink printableLink = new PrintableComponentLink() { Component = printable };
      return printableLink;
}

2.调用方法

us.ExportToExcel("excel", this.gridControl1);

3.dev设置列自适应

4.DevExpress Winform GridControl GridView 主从表(Master-Detail)导出Excel问题

gridView1.OptionsPrint.PrintDetails = true;//导出明细
gridView1.OptionsPrint.ExpandAllDetails = true;//导出所有明细,false的话,只会导出展开的明细

参考链接

主从表excel导出

关于DevExpress Winform GridControl GridView 主从表(Master-Detail)导出Excel问题_涛神-Dev 的博客-CSDN博客

通用excel导出

DevExpress WinForm通用控件导出Excel方法(支持多个控件分工作薄导出)_涛神-Dev 的博客-CSDN博客

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
WinForm中,可以通过自定义单元格样式来实现GridControl中单元格文字的不同颜色或背景色。具体步骤如下: 1. 在GridControl的Properties窗口中找到Appearance属性,将其设为DevExpress.XtraGrid.Views.Grid.DrawFocusRectStyle.None,这样可以去掉单元格的焦点框。 2. 在GridControl上双击打开GridView的Designer界面。 3. 选中要修改样式的列,找到AppearanceCell属性,单击右侧的“...”按钮打开AppearanceObject对象的编辑器。 4. 在AppearanceObject编辑器中,可以设置字体、背景色、前景色等属性,还可以通过条件格式化来实现更复杂的样式。例如,可以在FormatConditions列表中添加条件格式化规则,然后在Appearance属性中设置对应的样式。 5. 保存样式后,关闭Designer界面即可看到效果。 下面是一段示例代码,演示如何在GridView中实现单元格文字颜色的动态变化: ```csharp private void gridView1_CustomDrawCell(object sender, DevExpress.XtraGrid.Views.Base.RowCellCustomDrawEventArgs e) { if (e.Column.FieldName == "Status") { string status = e.CellValue.ToString(); if (status == "OK") { e.Appearance.ForeColor = Color.Green; } else if (status == "Warning") { e.Appearance.ForeColor = Color.Yellow; } else if (status == "Error") { e.Appearance.ForeColor = Color.Red; } } } ``` 这段代码在GridView的CustomDrawCell事件中,判断当前单元格的列名是否为“Status”,如果是,则根据单元格的值来设置不同的字体颜色。可以根据自己的需求修改相应的代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fyhs

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值