作者:semb | 来源:互联网 | 2024-11-02 15:15
通过在项目中引用NuGet包`ExcelDataReader`,可以实现高效地读取和导入Excel文件中的数据。具体方法是在项目中执行`Install-PackageExcelDataReader`命令,然后通过定义一个`LeadingIn`方法并传入上传文件的路径来完成数据导入。该方法不仅简化了代码逻辑,还显著提升了数据处理的效率和可靠性。
nuget 添加Install-Package ExcelDataReader
包
//FilePath为上传的文件路径
public void Leading_in(string FilePath)
{
var file = new FileStream(FilePath, FileMode.Open, FileAccess.Read);//FilePath为文件的路径带名字,FileMode.Open为打开文件,FileAccess.Read为以只读的方式打开
var excel = Excel.ExcelReaderFactory.CreateOpenXmlReader(file);
var dataset = excel.AsDataSet();//将表格导出为dataset格式
//循环插入数据到数据库
Model.production model = new Model.production();
BLL.production bll = new BLL.production();
int i = 0;
var lujing = HttpContext.Current.Session["lujing"].ToString();
foreach (DataRow dr in dataset.Tables[0].Rows)
{
if (i != 0 && lujing!="")
{
DataTable dt = new DataTable();
dt = new BLL.production().GetList_pro(" production_id=" + dr["Column1"]).Tables[0];
int n = int.Parse(dt.Rows.Count.ToString());
if (n == 0)
{
model.channel_id = 20;
model.category_id = 83;
model.production_id = int.Parse(dr["Column1"].ToString());
model.pmzc = dr["Column2"].ToString();
model.title1 = dr["Column3"].ToString();
model.author = dr["Column4"].ToString();
model.img_url1 = lujing + dr["Column5"].ToString();
model.size = dr["Column6"].ToString();
model.creation_year = dr["Column7"].ToString();
model.judge = dr["Column8"].ToString();
if (!string.IsNullOrEmpty(dr["Column10"].ToString()))
{
model.explain_1 = dr["Column10"].ToString();
}
model.explain_2 = dr["Column11"].ToString();
model.sort_id = 99;
if (bll.Add(model) <1)
{
}
}
else {
foreach (DataRow item in dt.Rows)
{
Model.production model_1 = bll.GetModel(int.Parse(item["id"].ToString()));
model_1.price_1 = dr["Column9"].ToString();
if (bll.Update(model_1))
{
}
}
}
}
i++;
}
}
红色部分为引入包后的初始化