IQueryable <ofsomeobject>导出到excel </ofsomeobject>

时间:2012-06-01 08:34:13

标签: c# linq entity-framework entity-framework-4 entity-framework-4.1

嗯,这肯定可能以前没有被问过。

我有一个返回IQueryable的方法,客户端要求是我们应该将其导出到excel而不在gridview中显示结果的一个特定示例。

有什么想法吗?

string strSql = BuildQuery();
            try
            {
                var list = RequestBaseBL.GetRequestByCustomQuery(strSql, DdlRequestType.SelectedValue).ToList();

1 个答案:

答案 0 :(得分:3)

在excel中导出看看:

http://epplus.codeplex.com/releases/view/42439

然后你可以创建自己的类来为IEnumerable生成excel导出

这里有一些提示(这些是更大的对象的一部分,所以只有提示,没有任何编译肯定)可能来自我的一个项目:

 public interface IExcelReporting : IServiceObject
    {
        ColumnsExcel Columns { get; }

        void SetDatasource(IEnumerable datasource);
        void SetHeaderLabelMerge(int columnMerge);
        void AddHeader(string label, string value);
        Byte[] ExportToExcel(string title, string author, DateTime date);
    }

实施的一个例子:

  public Byte[] ExportToExcel(string title, string author, DateTime date)
    {
        ExcelPackage package = new ExcelPackage();

        ExcelWorksheet worksheet = package.Workbook.Worksheets.Add(title);

if (_Columns != null)
            {

                Dictionary<int, Func<object, string>> internalMappingGetter = new Dictionary<int, Func<object, string>>();

                //create the Header of the body
                foreach (ColumnExcel entity in _Columns)
                {
                    worksheet.Cells[RowIndex, ColumnIndex].Value = entity.HeaderName;
                    worksheet.Cells[RowIndex, ColumnIndex].Style.WrapText = true;
                    BorderCell(worksheet.Cells[RowIndex, ColumnIndex]);
                    worksheet.Column(ColumnIndex).Width = entity.Width;
                    ColumnIndex++;
                }

                RowIndex++;

                if (_DataSource != null)
                {
                    foreach (Object o in _DataSource)
                    {
                        ColumnIndex = 1;
                        foreach (ColumnExcel column in _Columns)
                        {
                            column.Apply(worksheet.Cells[RowIndex, ColumnIndex], o);
                            worksheet.Column(ColumnIndex).BestFit = true;
                            worksheet.Cells[RowIndex, ColumnIndex].Style.WrapText = true;
                            //BorderCell(worksheet.Cells[RowIndex, ColumnIndex]);
                            ColumnIndex++;
                        }
                        RowIndex++;
                    }
                }

和列类:

public class ColumnsExcel : IEnumerable
    {
        List<ColumnExcel> _Columns;

        public ColumnsExcel()
        {
            _Columns = new List<ColumnExcel>();
        }


        public void AddInt(Func<object,int> getValue, string headerName, int width, string format)
        {
            ColumnExcel entity = new ColumnExcelInt(headerName, width, format, getValue);
            _Columns.Add(entity);
        }

        public void AddString(Func<object, string> getValue, string headerName, int width )
        {
            ColumnExcel entity = new ColumnExcelstring(headerName, width, getValue);
            _Columns.Add(entity);
        }

        public void AddDateTime(Func<object, DateTime?> getValue, string headerName, int width, string format)
        {
            ColumnExcel entity = new ColumnExcelDateTime(headerName, width, format, getValue);
            _Columns.Add(entity);
        }

        public void AddDecimal(Func<object, decimal> getValue, string headerName, int width, string format)
        {
            ColumnExcel entity = new ColumnExcelDecimal(headerName, width, format, getValue);
            _Columns.Add(entity);
        }

        public IEnumerator GetEnumerator()
        {
            return _Columns.GetEnumerator();
        }
    }

及其用途:

 //prepare the Ienumerable<MyObject>
 var interventi = GetInterventoSchedeConsuntivi()

 //prepare the report
 IExcelReporting report = ReportingFactory.GetInstance();
 report.SetDatasource(interventi);
 report.AddHeader("Lotto:", lotto);

 report.Columns.AddString((object v) => ((InterventoSchedeConsuntiviView)v).Lotto, "Lotto", 20);

using (System.IO.Stream s = File.Create(filepath))
                    {
                        byte[] csv = report.ExportToExcel(("titleFile", string.Empty, Servizi.DataOra.Now);
                        s.Write(csv, 0, csv.Length);
                    }