`
asd14828
  • 浏览: 30236 次
  • 性别: Icon_minigender_1
  • 来自: 太原
社区版块
存档分类
最新评论

NPOI 库 C# List<T> 操作类

    博客分类:
  • C#
阅读更多
编写背景:
    网上有返回DataTable和DataTable导入Excel的操作,目前系统是以List泛型,所以改成List泛型版的。写的不好请多指教!


public class operateExcel<T>
{
    public operateExcel()
    { 
    }
    /// <summary>
    /// 导出Excel
    /// </summary>
    /// <param name="lists"></param>
    /// <param name="head">中文列名对照</param>
    /// <param name="workbookFile">保存路径</param>
    public void getExcel(List<T> lists,Hashtable head, string workbookFile)
    { 
        try
        {
            HSSFWorkbook workbook = new HSSFWorkbook();
            MemoryStream ms = new MemoryStream();
            HSSFSheet sheet = workbook.CreateSheet() as HSSFSheet;
            HSSFRow headerRow = sheet.CreateRow(0) as HSSFRow;
            bool h = false;
            int j = 1;
            Type type = typeof(T);
            PropertyInfo[] properties = type.GetProperties();

            foreach (T item in lists)
            {
                HSSFRow dataRow = sheet.CreateRow(j) as HSSFRow;
                int i = 0;
                foreach (PropertyInfo column in properties)
                {
                    if (!h)
                    {
                        headerRow.CreateCell(i).SetCellValue(head[column.Name] == null ? column.Name : head[column.Name].ToString());
                        dataRow.CreateCell(i).SetCellValue(column.GetValue(item, null) == null ? "" : column.GetValue(item, null).ToString());
                    }
                    else
                    {
                        dataRow.CreateCell(i).SetCellValue(column.GetValue(item, null) == null ? "" : column.GetValue(item, null).ToString());
                    }
                    
                    i++;
                }
                h = true;
                j++;
            }
            workbook.Write(ms);
            ms.Flush();
            ms.Position = 0;
            sheet = null;
            headerRow = null;
            workbook = null;
            FileStream fs = new FileStream(workbookFile, FileMode.Create, FileAccess.Write);
            byte[] data = ms.ToArray();
            fs.Write(data, 0, data.Length);
            fs.Flush();
            fs.Close();
            data = null;
            ms = null;
            fs = null;
        }
        catch (Exception ee)
        {
            string see = ee.Message;
        }
    }
    /// <summary>
    /// 导入Excel
    /// </summary>
    /// <param name="lists"></param>
    /// <param name="head">中文列名对照</param>
    /// <param name="workbookFile">Excel所在路径</param>
    /// <returns></returns>
    public List<T> fromExcel(Hashtable head, string workbookFile)
    {
        try
        {
            HSSFWorkbook hssfworkbook;
            List<T> lists = new List<T>();
            using (FileStream file = new FileStream(workbookFile, FileMode.Open, FileAccess.Read))
            {
                hssfworkbook = new HSSFWorkbook(file);
            }
            HSSFSheet sheet = hssfworkbook.GetSheetAt(0) as HSSFSheet;
            IEnumerator rows = sheet.GetRowEnumerator();
            HSSFRow headerRow = sheet.GetRow(0) as HSSFRow;
            int cellCount = headerRow.LastCellNum;
            //Type type = typeof(T);
            PropertyInfo[] properties ;
            T t = default(T);
            for (int i = sheet.FirstRowNum + 1; i <= sheet.LastRowNum; i++)
            {
                HSSFRow row = sheet.GetRow(i) as HSSFRow;
                t = Activator.CreateInstance <T>();  
                properties = t.GetType().GetProperties();
                foreach (PropertyInfo column in properties)
                {
                    int j = headerRow.Cells.FindIndex(delegate(Cell c)
                            {
                                return c.StringCellValue==(head[column.Name] == null ? column.Name : head[column.Name].ToString());
                            });
                    if (j>=0&&row.GetCell(j) != null)
                    {
                        object value =valueType(column.PropertyType, row.GetCell(j).ToString());  
                        column.SetValue(t, value, null);
                    }
                }
                lists.Add(t);
            }
            return lists;
        }
        catch (Exception ee)
        {
            string see = ee.Message;
            return null;
        }
    }
    object valueType(Type t, string value)
    {
        object o=null;
        string strt = "String";
        if (t.Name == "Nullable`1")
        {
           strt= t.GetGenericArguments()[0].Name;
        }
        switch (strt)
        {
            case "Decimal":
                o=decimal.Parse(value);
                break;
            case "Int":
                o = int.Parse(value);
                break;
            case "Float":
                o = float.Parse(value);
                break;
            case "DateTime":
                o = DateTime.Parse(value);
                break;
            default:
                o = value;
                break;
        }
        return o;
    }
}

1
1
分享到:
评论

相关推荐

    C# Excel导入导出,基于NOPI(兼容xls和xlsx)

    NPOI提供了API来将Excel工作表转换为DataTable,或者将数据从List&lt;T&gt;导入到Excel工作表。 - **DataTable转List&lt;T&gt;**:首先,你需要读取Excel文件中的工作表,然后将工作表数据转换成DataTable。NPOI的`...

    C# NPOI 导出Excel

    C# NPOI库是一个非常实用的开源项目,专门用于处理Microsoft Office文件,尤其是Excel文档。在.NET开发环境中,如果你需要在C#程序中生成、读取或修改Excel文件,NPOI是一个理想的选择。本资源提供的"004...

    C# NPOI Word 读取

    3. 遍历文档段落:`XWPFDocument`对象包含了一个`List&lt;XWPFParagraph&gt;`类型的`Paragraphs`属性,你可以通过遍历这个列表来获取每个段落的内容: ```csharp foreach (var paragraph in document.Paragraphs) { ...

    NPOIHelper 用于C#操作Execl类

    NPOIHelper可能提供了读取单个工作表的方法,如`ReadSheet(string filePath, string sheetName, List&lt;string[]&gt; data)`,返回一个包含工作表所有行数据的列表。 NPOI库内部使用了两种不同的组件来处理不同版本的...

    Unity文档操作使用的NPOI库文件

    public void WriteToExcel(string filePath, string sheetName, List&lt;string[]&gt; data) { IWorkbook workbook; if (filePath.EndsWith(".xls")) { workbook = new HSSFWorkbook(); } else if (filePath.EndsWith...

    NPOI读取Excel,并添加操作Excel增加一列

    List&lt;string&gt; importStatuses = new List&lt;string&gt; { "成功", "失败", "部分成功" }; // 示例数据 for (int rowIndex = 0; rowIndex &lt; sheet.LastRowNum; rowIndex++) { IRow row = sheet.GetRow(rowIndex) ?? ...

    C#使用Nopi读写word

    List&lt;List&lt;List&lt;string&gt;&gt;&gt; workBook = new List&lt;List&lt;List&lt;string&gt;&gt;&gt;(); for (int i = 0; i &lt; sheetsCount; i++) { // 读取每一个Sheet ISheet sheet = hssfworkbook.GetSheetAt(i); // 获取当前Sheet的最大...

    ASP.NET/C# 使用NPOI 将数据导入到模板Excel[支持xlsx][源代码]

    public void ExportToExcel(List&lt;DataRow&gt; dataList, string templateFilePath, string outputFilePath) { using (var workbook = new XSSFWorkbook(templateFilePath)) { var sheet = workbook.GetSheetAt(0); /...

    c#npoi获取数据有效性序列下拉框的值

    在IT行业中,尤其是在数据分析、报表生成以及数据导入导出等领域,C#结合NPOI库是一种常见的解决方案。NPOI是.NET平台上的一个开源库,它允许开发者读写Microsoft Office格式的文件,如Excel(.xlsx)和Word(.docx...

    C# Excel导出

    List&lt;T&gt;继承自Collection&lt;T&gt;,提供了丰富的操作方法,如添加、删除、查找等,适合用来存储待导出的数据。 2. **创建Excel工作簿和工作表**:无论使用哪个库,都需要先创建一个新的Excel工作簿(Workbook)和工作表...

    C#导出的EXCEL类

    public void ExportToExcel&lt;T&gt;(string filePath, List&lt;T&gt; dataList, string sheetName) { // 创建Excel包 using (var package = new ExcelPackage(new FileInfo(filePath))) { // 添加工作表 var worksheet =...

    npoi (excel导入导出)帮助类

    这个"npoi (excel导入导出)帮助类"是一个专门为处理Excel数据导入和导出设计的工具集,它利用Npoi的功能来简化操作流程。下面我们将详细探讨Npoi的核心功能以及如何使用这个帮助类来实现Excel的导入和导出。 首先,...

    ASP.NET(C#)手動排序

    C#提供了多种排序方法,其中最常用的是`List&lt;T&gt;.Sort()`方法,它使用了快速排序算法。但当你需要自定义排序规则,例如按照特定属性或自定义比较逻辑进行排序时,就需要手动实现排序。 1. **自定义IComparable接口**...

    使用C#合并头结构一致的excel、csv文件

    对于Excel,我们可以使用`EPPlus`库来操作.xlsx文件,或者`NPOI`库来操作.xls文件。首先确保已安装这两个库: ```sh Install-Package CsvHelper Install-Package EPPlus Install-Package NPOI ``` 接下来,我们将...

    C# excel 操作类 支持excel的各种导出

    2. **将数据导出到Excel**:这是基本的导出功能,可以将任何数据结构(如List&lt;T&gt;、数组或自定义对象)转换为Excel格式。数据通常会映射到Excel的单元格,支持多种数据类型,如字符串、数字、日期等。 3. **支持各种...

    excel中取出泛型数据存入泛型的list中

    List&lt;MyClass&lt;String&gt;&gt; dataList = new ArrayList&lt;&gt;(); for (Row row : sheet) { if (row.getRowNum() == 0) continue; // 跳过表头 MyClass&lt;String&gt; obj = new MyClass&lt;&gt;(); obj.setProperty1(row.getCell(0)...

    C#利用数据流实现导入导出excle文件的类

    在C#中,我们可以使用`System.IO`命名空间下的类,如`FileStream`、`BinaryReader`和`BinaryWriter`来操作数据流。对于Excel文件,由于它们通常是以二进制格式存储的,因此使用这些类非常合适。 导入Excel文件的...

    C#中PDF文件转WORD文件

    遍历每一页时,提取出文字和图像,并存储到适当的数据结构中,例如`List&lt;string&gt;`和`List&lt;Bitmap&gt;`。 提取出PDF内容后,接下来是将这些数据转换为Word文档。Microsoft的Office Interop库可以用来创建和操作Word文档...

    Excel-数据分类导出至多个Sheet NPOI.dll

    标题中的“Excel-数据分类导出至多个Sheet NPOI.dll”表明这是一个关于使用NPOI库来操作Excel文件,特别是将数据按照类别分到不同的工作表(Sheet)中的技术主题。NPOI是一个开源的.NET库,它允许开发者读写...

    asp.net 利用Npoi脱离Office导入导出Excel

    2. 导出Excel:这个方法接受数据源(如DataTable或List&lt;T&gt;),然后创建一个新的Excel文件并填充数据。你可以创建工作簿,添加工作表,然后遍历数据源,为每一项创建一行,并填充单元格。 在实际应用中,你可能还...

Global site tag (gtag.js) - Google Analytics