0

在我的 MVC 5 应用程序中,我使用 LinqToExcel 将数据从 Excel 文件导入 SQL Server 数据库表。以下是获取数据并保存到数据库的代码。

var dataDirectory = new DirectoryInfo(Server.MapPath("~/App_Data/Data/"));
            DirectoryInfo dir = new DirectoryInfo(dataDirectory.ToString());//reading the director at a specific path
            FileInfo[] info = dir.GetFiles("*.*");//getting the list of files in the director
            foreach(FileInfo f in info)
            {
                dataFileName = f.FullName;//getting full file name
                fileExt = f.Extension;//getting the file extension
            }
            if(fileExt == ".xlsx")
            {
                var excel = new ExcelQueryFactory();
                excel.FileName = dataFileName;
                //mapping the database table columns to EXCEL columns
                excel.AddMapping<WASA_Bill_Detail>(s => s.AccountNo, "ACCOUNTNO");
                excel.AddMapping<WASA_Bill_Detail>(s => s.BillNo, "BILLNO");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Category, "CATEGORY");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Billing_Period, "BILLING_PERIOD");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Name, "NAME");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Address, "ADDRESS");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Issue_Date, "ISSUE_DATE");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Due_Date, "DUE_DATE");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Water_Bill, "WATER_BILL");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Sewerage_Bill, "SEWERAGE_BILL");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Aquifer_Charges, "AQUIFER");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Current_Amount, "CURRENT AMOUNT");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Arrears, "ARREARS");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Service_Charges, "SERVICE CHARGES");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Payable_within_DueDate, "PAYABLE WITHIN DUEDATE");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Surcharge, "SURCHARGE");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Payable_after_DueDate, "AFTER DUE DATE");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Payment_History_1, "PAY HISTORY 1");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Paid_1, "PAID 1");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Payment_History_2, "PAY HISTORY 2");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Paid_2, "PAID 2");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Payment_History_3, "PAY HISTORY 3");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Paid_3, "PAID 3");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Area, "AREA");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Water_Rate, "WATER RATE");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Sewerage_Rate, "SEWER RATE");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Discharge_Basis, "DISCHAGE");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Pump_Size, "PUMP SIZE");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Ferrule_Size, "FERRULE SIZE");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Meter_Type, "METER TYPE");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Meter_Status, "METER STATUS");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Current_Reading, "CURRENT READING");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Last_Readin, "LAST READING");
                excel.AddMapping<WASA_Bill_Detail>(s => s.Water_Aquiffer_Charges, "WATER AQUIFER CHARGES");

                var excelData = from x in excel.Worksheet<WASA_Bill_Detail>() select x;                

                foreach(var data in excelData)
                {
                    if (ModelState.IsValid)
                    {
                        db.WASA_Bill_Detail.Add(wASA_Bill_Detail);
                        db.SaveChanges();                        
                    }
                }
                return RedirectToAction("Index");
            }

在上面的代码中,我将属性映射到了 excel 列。

现在的问题是当我尝试将数据保存到数据库表中时,发生了“System.FormatException”。异常详情如下

System.FormatException was unhandled by user code
  HResult=-2146233033
  Message=Input string was not in a correct format.
  Source=mscorlib
  StackTrace:
       at System.Number.StringToNumber(String str, NumberStyles options, NumberBuffer& number, NumberFormatInfo info, Boolean parseDecimal)
       at System.Number.ParseDecimal(String value, NumberStyles options, NumberFormatInfo numfmt)
       at System.Convert.ToDecimal(String value, IFormatProvider provider)
       at System.String.System.IConvertible.ToDecimal(IFormatProvider provider)
       at System.Convert.ChangeType(Object value, Type conversionType, IFormatProvider provider)
       at System.Convert.ChangeType(Object value, Type conversionType)
       at LinqToExcel.Extensions.CommonExtensions.Cast(Object object, Type castType)
       at LinqToExcel.Query.ExcelQueryExecutor.GetTypeResults(IDataReader data, IEnumerable`1 columns, QueryModel queryModel)
       at LinqToExcel.Query.ExcelQueryExecutor.GetDataResults(SqlParts sql, QueryModel queryModel)
       at LinqToExcel.Query.ExcelQueryExecutor.ExecuteCollection[T](QueryModel queryModel)
       at Remotion.Data.Linq.Clauses.StreamedData.StreamedSequenceInfo.ExecuteCollectionQueryModel[T](QueryModel queryModel, IQueryExecutor executor)
       at Remotion.Data.Linq.Clauses.StreamedData.StreamedSequenceInfo.ExecuteQueryModel(QueryModel queryModel, IQueryExecutor executor)
       at Remotion.Data.Linq.QueryModel.Execute(IQueryExecutor executor)
       at Remotion.Data.Linq.QueryProviderBase.Execute[TResult](Expression expression)
       at Remotion.Data.Linq.QueryableBase`1.GetEnumerator()
       at LINQToSQLTest.Controllers.WASA_Bill_DetailController.Create(WASA_Bill_Detail wASA_Bill_Detail, HttpPostedFileBase[] Files) in e:\Projects\DotNet\MVC5\LINQToSQLTest\LINQToSQLTest\Controllers\WASA_Bill_DetailController.cs:line 133
       at lambda_method(Closure , ControllerBase , Object[] )
       at System.Web.Mvc.ActionMethodDispatcher.Execute(ControllerBase controller, Object[] parameters)
       at System.Web.Mvc.ReflectedActionDescriptor.Execute(ControllerContext controllerContext, IDictionary`2 parameters)
       at System.Web.Mvc.ControllerActionInvoker.InvokeActionMethod(ControllerContext controllerContext, ActionDescriptor actionDescriptor, IDictionary`2 parameters)
       at System.Web.Mvc.Async.AsyncControllerActionInvoker.ActionInvocation.InvokeSynchronousActionMethod()
       at System.Web.Mvc.Async.AsyncControllerActionInvoker.<BeginInvokeSynchronousActionMethod>b__39(IAsyncResult asyncResult, ActionInvocation innerInvokeState)
       at System.Web.Mvc.Async.AsyncResultWrapper.WrappedAsyncResult`2.CallEndDelegate(IAsyncResult asyncResult)
       at System.Web.Mvc.Async.AsyncResultWrapper.WrappedAsyncResultBase`1.End()
       at System.Web.Mvc.Async.AsyncResultWrapper.End[TResult](IAsyncResult asyncResult, Object tag)
       at System.Web.Mvc.Async.AsyncControllerActionInvoker.EndInvokeActionMethod(IAsyncResult asyncResult)
       at System.Web.Mvc.Async.AsyncControllerActionInvoker.AsyncInvocationWithFilters.<InvokeActionMethodFilterAsynchronouslyRecursive>b__3f()
       at System.Web.Mvc.Async.AsyncControllerActionInvoker.AsyncInvocationWithFilters.<>c__DisplayClass48.<InvokeActionMethodFilterAsynchronouslyRecursive>b__41()
  InnerException: 

关于上述异常的任何帮助

4

0 回答 0