MVC, 上传 CSV, int.Parse(), "Input string was not in a correct format."



我知道以前有人问过这个问题,我已经尽力找到一个可以帮助我解决问题的答案,但没有成功。我不同意重复的问题,但我希望你仍然想帮助我。

提前感谢!

我制作了一个解决方案,可以将csv文件上传到我的sql数据库中。当我运行代码时,选择文件并按下"上传",我会收到以下错误:"输入字符串的格式不正确。"

错误正在我的控制器中抛出LearningNumbers.LearningNumber Id=int.Parse(values[0])

我的CSV

LearningNumberId;Note;Activity;Price
1;Node1;her er node 1;22
2;Node1;her er node 2;33

我的型号:

namespace MTH_SQL.Model
{
    public class LearningNumberRecord
    {
        [Key]
        public int LearningNumberId { get; set; }
        public string Note { get; set; }
        public string Activity { get; set; }
        public int Price { get; set; }
    }
}

我的控制器:

namespace MTHoejgaard.Controllers
{
public class HomeController : Controller
{
    private MTHoejgaardContext db = new MTHoejgaardContext();
    public ActionResult Index()
    {
        return View();
    }
    [HttpPost]
    public ActionResult Index(HttpPostedFileBase File)
    {
        if (File != null && File.ContentLength > 0)
        {
            StreamReader csvReader = new StreamReader(File.InputStream);
            {
                string inputLine = "";
                while ((inputLine = csvReader.ReadLine()) != null)
                {
                    string[] values = inputLine.Split(new Char[] { ';' });
                    LearningNumberRecord LearningNumbers = new LearningNumberRecord();
                    LearningNumbers.LearningNumberId = int.Parse(values[0]);  // <-- IT THROWS THE ERROR HERE
                    LearningNumbers.Note = values[1];
                    LearningNumbers.Activity = values[2];
                    LearningNumbers.Price = int.Parse(values[3]);
                    db.LearningNumbers.Add(LearningNumbers);
                    db.SaveChanges();
                }
                csvReader.Close();
            }
        }
        return RedirectToAction("Index");
    } 
}

我的观点:

@using (Html.BeginForm("Index", "Home", FormMethod.Post, new { enctype = "multipart/form-data" }))
{
    <input type="file" name="File" id="File" />
    <input type="submit" name="Submit" value="Upload" />
    <span>@ViewBag.Message</span>
}

将CSV文件更改为(删除第一行):

1;Node1;her er node 1;22
2;Node1;her er node 2;33

或者,在解析文件时跳过第一行。

相关内容

最新更新