ASP.NET WebApi批量导入数据库(优化)

批量导入数据

说明:
(1)参考第一篇博客,读取excel中数据批量导入数据库,[链接](http://blog.csdn.net/realjh/article/details/78546072)
(2)本篇博客是对批量录入操作进行优化,重点在对excel工作薄中的数据进行获取,相信大家
能够准确拿到excel表中的数据,那么批量录入操作就是轻而易举的事情了,而且还可以对数据
的准确性进行一系列相关的验证等等。
读取Excel工作薄代码如下:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
//引用的类库命名空间
using System.Data;
using System.IO;
using NPOI.SS.UserModel;//引用创建excel工作薄变量
using NPOI.XSSF.UserModel;//工作薄从文件流中获取excel表中的数据


namespace TestImportFromExcel
{
    public class Program
    {

        static void Main(string[] args)
        {
            //待读取的excel文件路径
            string filepath = @"C:/Users/Administrator/Desktop/测试导入.xlsx";
            //读取操作成功与失败的提示消息
            string message=string.Empty;
            //接收sheet表中属性列名
            List<List<string>> ColumnName = new List<List<string>>();
            //接收sheet表中所有数据
            List<List<string>> ColumnData = new List<List<string>>();
            bool act = GetDataFromExcel(filepath,ColumnName,ColumnData,ref message );
            Console.ReadKey();
        }
        /// <summary>
        /// 读取exel表的操作结果消息提示
        /// </summary>
        public static bool GetDataFromExcel(string filePath, List<List<string>> columnName, List<List<string>> columnData,ref string message)
        {
            //监视数据获取操作是否成功
            bool bflag = false;
            if (File.Exists(filePath))
            {
                //首先判断文件是否存在
                //创建一个excel工作薄对象
                IWorkbook workBook = new XSSFWorkbook(filePath);
                if (workBook.NumberOfSheets > 0)
                {
                    #region 创建读取sheet表的对象
                    //拿到sheet个数:说明此处可以作为判断用户是否修改我们模板的sheet数量
                    int length = workBook.NumberOfSheets;
                    //创建一个sheet薄对象
                    ISheet Sheet = null;
                    //创建一个行单元对象
                    IRow Row = null;
                    //创建一个列单元对象
                    ICell Cell = null;
                    #endregion
                    #region 循环遍历读取每个sheet表的数据
                    for (int i = 0; i < length; i++)
                    {
                        #region 做默认读取第一个sheet工作薄
                        //控制默认情况下只读取第一个sheet
                        if (i == 1)
                        {
                            //不让读取第二个工作薄,跳出循环
                            break;
                        }
                        #endregion
                        //拿到第一个sheet工作薄
                        Sheet = workBook.GetSheetAt(i);
                        //判断表中有没有待录入的数据记录
                        int len = Sheet.LastRowNum;
                        #region 需要默认去掉第一行样例数据
                        if (len > 0)
                        {
                            //接收数据类型中间变量
                            string value = string.Empty;
                            #region 读取遍历每行记录,获取数据。v=0表示第一列名称属性
                            for (int v = 0; v < len; v++)
                            {
                                //获取单独的一行数据
                                Row = Sheet.GetRow(v);
                                #region 遍历每个小单元格获取单元格内容
                                //拿到改条记录有多少列
                                int number = Row.LastCellNum;
                                string tempVariable = string.Empty;
                                //中间集合记录excel每个条记录的单元格内容
                                List<string> tempList = new List<string>();
                                #region 列名称和列数据分区分开获取
                                //判断是否是遍历第一个列名称
                                if (v == 0)
                                {
                                    //拿到列集合,并获取单元格内容
                                    for (int r = 0; r < number; r++)
                                    {
                                        Cell = Row.GetCell(r);
                                        value = string.Empty;
                                        value = Cell == null ? "Blank" : Cell.CellType.ToString();
                                        #region 匹配单元格类型
                                        switch (Cell.CellType.ToString())
                                        {
                                            case "String":
                                                tempVariable = Cell.StringCellValue;
                                                break;
                                            case "Numeric":
                                                #region 识别是日期还是数值
                                                //判断是日期还是数值类型
                                                if (Cell.DateCellValue.ToString("yyyy-MM-dd HH:ss:mm") == "1900-01-01 00:00:00")
                                                {
                                                    //表示数值类型
                                                    tempVariable = Cell.NumericCellValue.ToString();
                                                }
                                                else
                                                {
                                                    tempVariable = Cell.DateCellValue.ToString("yyyy-MM-dd HH:ss:mm");
                                                }
                                                #endregion
                                                break;
                                            case "Blank":
                                                tempVariable = Cell.StringCellValue;
                                                break;
                                            default:
                                                message = "批量录入操作失败!Excel表中第【" + Row.GetCell(0).StringCellValue + "】记录有不符合规范的数据记录。";
                                                return bflag;
                                                break;
                                        }
                                        #endregion
                                        #region   做sql语句操作需要的数据
                                        tempList.Add(tempVariable);
                                        #endregion
                                    }
                                    //记录整个列名称集合
                                    columnName.Add(tempList);
                                }
                                else
                                {
                                    //清空所有数据
                                    tempList = new List<string>();
                                    //表示遍历列数据(包含样例记录)此处需要考核进行去除样例数据批量录入数据库
                                    //拿到列集合,并获取单元格内容
                                    for (int r = 0; r < number; r++)
                                    {
                                        Cell = Row.GetCell(r);
                                        value = string.Empty;
                                        value = Cell == null ? "Blank" : Cell.CellType.ToString();
                                        #region 匹配单元格类型
                                        switch (value)
                                        {
                                            case "String":
                                                tempVariable = Cell.StringCellValue;
                                                break;
                                            case "Numeric":
                                                #region 识别是日期还是数值
                                                //判断是日期还是数值类型
                                                if (Cell.DateCellValue.ToString("yyyy-MM-dd HH:ss:mm") == "1900-01-01 00:00:00")
                                                {
                                                    //表示数值类型
                                                    tempVariable = Cell.NumericCellValue.ToString();
                                                }
                                                else
                                                {
                                                    tempVariable = Cell.DateCellValue.ToString("yyyy-MM-dd HH:ss:mm");
                                                }
                                                #endregion
                                                break;
                                            case "Blank":
                                                tempVariable =string.Empty;
                                                break;
                                            default:
                                                message = "批量录入操作失败!Excel表中第【" + Row.GetCell(0).StringCellValue + "】记录有不符合规范的数据记录。";
                                                return bflag;
                                                break;
                                        }
                                        #endregion
                                        #region   做sql语句操作需要的数据
                                        tempList.Add(tempVariable);
                                        #endregion
                                    }
                                    //记录到整个数据集合中
                                    columnData.Add(tempList);
                                }
                                #endregion
                                #endregion
                            }
                            #endregion
                            bflag = true;
                            message = "操作成功!【" + workBook.GetSheetName(i) + "】工作薄中的数据已被获取。";
                            return bflag;
                        }
                        else
                        {
                            message = "操作失败!【" + workBook.GetSheetName(i) + "】工作薄中没有待批量录入的数据。";
                        }
                        #endregion
                    }
                    #endregion
                }
                else
                {
                    message = "操作失败!该Excel文件中没有sheet工作薄。";
                }
            }
            return bflag;
        }
    }
}
结语
(1)本篇博客是对上一篇批量录入获取excel表中数据方法的重写和优化。解决方案后续上传。
(2)欢迎博友提出意见和建议,相互学习,共同进步。
(3)Demo下载地址:http://download.csdn.net/download/realjh/10166995
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ASP.NET Web API 是一个快速开发框架,用于构建用于Web应用程序的Web服务。它基于ASP.NET和HTTP协议,并充分利用了HTTP特性。 ASP.NET Web API 提供了一种简单明了的方式来创建和发布Web API,使开发人员能够轻松地将数据和服务暴露给客户端应用程序,无论是Web应用程序、移动应用程序还是其他类型的客户端。 ASP.NET Web API 提供了广泛的特性和功能,包括: 1. 灵活的路由配置:通过使用属性路由或传统的路由映射,开发人员可以轻松地定义API的URL结构和访问规则。 2. 内建HTTP支持:ASP.NET Web API完全支持HTTP协议,并提供了与HTTP相关的功能,如GET、POST、PUT、DELETE等HTTP动词和状态码处理。 3. 内容协商:ASP.NET Web API 可以根据客户端的要求,动态选择并返回不同的响应内容类型,如JSON、XML或其他自定义媒体类型。 4. 模型绑定和验证:ASP.NET Web API 提供了强大的模型绑定和验证功能,可以自动将请求数据绑定到相应的模型并进行验证。 5. 信息路由和版本控制:ASP.NET Web API 支持信息路由和版本控制,可以根据不同的请求信息选择不同的版本和实现。 6. 异常处理:ASP.NET Web API 提供了全面的异常处理机制,可以捕获和处理各种异常,并返回友好和有效的错误信息给客户端。 7. 安全性和身份验证:ASP.NET Web API 支持各种身份验证和安全性机制,如基于角色的授权、OAuth 2.0等。 总之,ASP.NET Web API 提供了一个高效、灵活和可扩展的框架,使开发人员能够快速构建和发布Web服务,并能适应不同类型的客户端应用程序。无论是构建企业级应用程序还是移动应用程序,ASP.NET Web API 都能够提供稳定可靠的解决方案。 ### 回答2: ASP.NET WebAPI是一种基于ASP.NET框架的快速开发框架。它主要用于构建和发布RESTful的Web服务,使开发者能够更快速地创建可扩展、可用性高的WebAPI应用程序。 首先,ASP.NET WebAPI提供了开箱即用的特性,使得开发者能够快速地创建基于HTTP协议的API。它支持多种数据格式,如JSON和XML,以及多个身份验证和授权方式,如基于角色和令牌的身份验证,使得开发者可以根据项目需求选择合适的方式来保护API。 其次,ASP.NET WebAPI提供了丰富的路由和绑定特性,使得开发者能够通过简单的配置和属性标记来定义API的路由规则和参数绑定方式。这种灵活性和可配置性使得开发者能够更轻松地处理不同的请求和响应,并提供符合预期的结果。 另外,ASP.NET WebAPI还提供了强大的行为和过滤器特性,例如认证过滤器、授权过滤器和异常过滤器等,使得开发者能够在不同阶段对请求进行处理和验证。同时,开发者还可以通过自定义过滤器来扩展现有特性或添加新的行为和过滤器。 此外,ASP.NET WebAPI还提供了易于测试和部署的特性。开发者可以使用单元测试框架对API进行测试,并通过ASP.NET的集成测试工具进行端到端的测试。同时,ASP.NET WebAPI还支持自托管和IIS托管两种部署方式,使得开发者能够更方便地部署和维护API应用程序。 综上所述,ASP.NET WebAPI是一个功能强大、易于使用和高效的快速开发框架。它提供了丰富的特性和可扩展性,使开发者能够更快速地构建和发布高质量的WebAPI应用程序。 ### 回答3: ASP.NET Web API 是一个用于构建基于HTTP协议的Web服务的框架,它可以让开发人员更快速、更高效地开发Web应用程序。 首先,ASP.NET Web API 提供了快速创建和部署Web服务的能力。通过使用ASP.NET Web API,开发人员可以轻松地创建RESTful风格的API,并将其部署到云端或本地服务器上。与传统的ASP.NET MVC相比,ASP.NET Web API 提供了更简洁、更轻量级的开发体验,让开发人员可以更专注于服务端逻辑的编写。 其次,ASP.NET Web API 提供了丰富的功能和工具,帮助开发人员更快速地构建和调试Web服务。它支持多种数据格式,包括JSON和XML,提供了强大的序列化和反序列化功能,可以轻松地处理来自客户端的请求和响应数据。此外,ASP.NET Web API 还支持组织代码的特性,如路由、过滤器和模型绑定等,让开发人员可以更轻松地组织和管理代码。 最后,ASP.NET Web API 具有良好的可扩展性和灵活性。它可以很容易地和其他ASP.NET 项目集成,如ASP.NET MVC和ASP.NET Core等。开发人员可以利用现有的ASP.NET技术和工具来开发和扩展Web API,并利用ASP.NET的生态系统来提供更丰富的功能和支持。 总之,ASP.NET Web API 是一个快速开发框架,它提供了方便、高效的开发体验,让开发人员可以更快速地构建和部署基于HTTP协议的Web服务。无论是构建RESTful风格的API,还是处理来自客户端的请求和响应数据ASP.NET Web API 都是一个强大的工具和框架。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值