我需要一种创建对象列表的方法,其中对象来自字符串
例如,我希望将以下内容转换为对象列表
Dim categoryList as IList(Of "classname") = new List(Of "class name")
最终结果
Dim categoryList As IList(Of BO.Store.Category) = New List(Of BO.Store.Category)
感谢 xxbbcc 为我指明了正确的方向。我想出了下面的解决方案,它可以让我上传任何 csv 文件并将其解析为 x 对象列表。
这是通过 dropzone 上传文件以及表名、对象类名和映射类名来实现的。这现在允许我使用准备导入临时表的 csvhelper 解析文件的内容。
<AcceptVerbs(HttpVerbs.Post), BaseViewModelFilter>
Function Upload(model As ImportUploadViewModel) As JsonResult
Dim balUpload As BAL.Upload = New BAL.Upload()
Dim balImport As BAL.Import = New BAL.Import()
Dim folder As String = String.Format("{0}tmp\import\category", Server.MapPath("\"))
Dim result = balUpload.SaveFiles(Request, folder, UserProfile.ID)
Dim importClassType = Type.[GetType](String.Format("Roxybox.BO.{0}", model.EntityClass))
Dim importClassMapType = Type.[GetType](String.Format("Roxybox.BO.{0}", model.EntityMap))
Dim records As IList
' Import all successful files
For Each successFile As String In result("success")
' Parse csv file
Using sr = New StreamReader(String.Format("{0}\{1}", folder, successFile))
Dim reader = New CsvReader(sr)
reader.Configuration.RegisterClassMap(importClassMapType)
records = reader.GetRecords(importClassType).ToList()
End Using
For Each category In records
Dim data As BO.Import = New BO.Import()
With data
.EntityModel = model.EntityModel
.Data = JsonConvert.SerializeObject(category)
.UserProfileID = UserProfile.ID
.Filename = successFile
.Status = "pending"
End With
balImport.Save(data, UserProfile.ID)
Next
Next
Return Json(result, JsonRequestBehavior.AllowGet)
End Function