экспорт IEnumerable <T>в Excel - PullRequest
       20

экспорт IEnumerable <T>в Excel

10 голосов
/ 26 июля 2010

Кто-нибудь знает, как или какую-нибудь библиотеку использовать для этого?

Ответы [ 3 ]

15 голосов
/ 26 июля 2010

Код ниже - это код, который я использую для преобразования IEnumerable<T> в таблицу данных, содержащую столбцы, названные для каждого свойства, а также значения каждого элемента в IEnumerable в виде строк. Это очень маленький переход к сохранению его в виде файла CSV

public class IEnumerableToDataTable
{
    public  static DataTable CreateDataTableForPropertiesOfType<T>()
    {
        DataTable dt = new DataTable();
        PropertyInfo[] piT = typeof(T).GetProperties();

        foreach (PropertyInfo pi in piT)
        {
            Type propertyType = null;
            if (pi.PropertyType.IsGenericType)
            {
                propertyType = pi.PropertyType.GetGenericArguments()[0];
            }
            else
            {
                propertyType = pi.PropertyType;
            }
            DataColumn dc = new DataColumn(pi.Name, propertyType);

            if (pi.CanRead)
            {
                dt.Columns.Add(dc);
            }
        }

        return dt;
    }

    public static DataTable ToDataTable<T>(IEnumerable<T> items)
    {
        var table = CreateDataTableForPropertiesOfType<T>();
        PropertyInfo[] piT = typeof(T).GetProperties();

        foreach (var item in items)
        {
            var dr = table.NewRow();

            for (int property = 0; property < table.Columns.Count; property++)
            {
                if (piT[property].CanRead)
                {
                    dr[property] = piT[property].GetValue(item, null);
                }
            }

            table.Rows.Add(dr);
        }
        return table;
    }
}

Итак, вы можете написать следующее для преобразования ваших данных в таблицу данных:

IEnumerable<Thing> values = GetMyIEnumerableValues();

var tableOfData = IEnumerableToDataTable.ToDataTable(values);

Как только он будет там, довольно просто записать его в файл CSV или любой другой формат по вашему выбору, поскольку вся «хитрая» работа по отражению для извлечения данных из IEnumerable<T> уже выполнена.

3 голосов
/ 26 июля 2010
1 голос
/ 05 января 2017

Я решил проблему, подобную той, которую вы просили.Как у вас есть IEnumerable

IEnumerable<TaskSheetHead> taskSheetHead = new TaskSheetHeadService().GetEmployeeTimesheet(entity);

Так что если вы хотите сделать из этого превосходство, просто создайте рабочую книгу

var workbook = new HSSFWorkbook();
var sheet = workbook.CreateSheet();

И итерируйте с циклом, а затем добавьте его на лист

foreach (TaskSheetHead taskSheethead in taskSheetHead)
            {
                //decimal totalTask = decimal.Zero;
                //double totalTime = 0;

                foreach (TaskSheet taskSheet in taskSheethead.TaskSheets)
                {
                    var row2 = sheet.CreateRow(rowNumber++);
                    row2.CreateCell(0).SetCellValue(taskSheethead.Date.ToString("MMMM dd, yyyy"));
                    row2.CreateCell(1).SetCellValue(taskSheet.Task.Project.ProjectName + ":" + taskSheet.Task.Title + "-" + taskSheet.Comment);
                    row2.CreateCell(2).SetCellValue(taskSheet.ExpendedHour);
                    row2.CreateCell(3).SetCellValue(taskSheet.IsBilledToClient);
                    //totalTask += 1;
                    //totalTime += taskSheet.ExpendedHour;
                }
                var row3 = sheet.CreateRow(rowNumber++);
                row3.CreateCell(0).SetCellValue("");
                row3.CreateCell(1).SetCellValue("");
                row3.CreateCell(2).SetCellValue("");
                row3.CreateCell(3).SetCellValue("");

            }

Здесь у меня есть другой дочерний список, поэтому я повторил, используя внутренний цикл.Делай как хочешь.

...