雙引號這是我從一個文本文件進入mysql數據庫如何忽略文本文件
我想這是
Product_Name Product_Price QTY
Pepsi 30 64
Coke 35 24
Sandwich 60 14
這是代碼。
try
{
var files = from file in Directory.EnumerateFiles(@"C:\Users\K\Desktop\New folder", "*.txt", SearchOption.AllDirectories)
from line in File.ReadLines(file)
select new
{
File = file,
Line = line
};
foreach (var f in files)
{
Console.WriteLine("{0}\t{1}", f.File, f.Line);
using (StreamReader sr = new StreamReader(f.File))
{
foreach (string line in File.ReadAllLines(f.File).SkipWhile(x => !x.Contains("[Start]")))
{
string readLine;
do
{
readLine = sr.ReadLine();
string[] readLineSplit = readLine.Split('|');
if(readLineSplit.Length > 1)
{
using (MySqlConnection con = new MySqlConnection(@"server=localhost;database=test;uid=root;pwd=pw;"))
{
con.Open();
MySqlCommand cmd = new MySqlCommand("INSERT INTO Products(Product_Name, Product_Price, QTY) VALUES (@Product_Name, @Product_Price, @QTY)", con);
cmd.Parameters.AddWithValue("@Product_Name", readLineSplit[0].ToString());
cmd.Parameters.AddWithValue("@Product_Price", readLineSplit[1].ToString());
cmd.Parameters.AddWithValue("@QTY", readLineSplit[2]);
cmd.ExecuteNonQuery();
}
}
} while (!sr.EndOfStream);
}
問題2:我有兩個文本文件在我的路徑,任何想法爲什麼只有一個文本文件插入到我的數據庫?
問每個問題 – 2015-04-02 07:04:02
1個提問除了你有我建議尋找到[Microsoft.VisualBasic.FileIO.TextFieldParser]的答案(https://msdn.microsoft.com/en-我們/庫/ MS12 8081(v = vs.110).aspx),因爲您只需指定[HasFieldsEnclosedInQuotes](https://msdn.microsoft.com/en-us/library/microsoft.visualbasic.fileio.textfieldparser.hasfieldsenclosedinquotes(v = vs。 110)的.aspx)。 – Filburt 2015-04-02 07:16:26
要回答問題2,我們需要查看發生了什麼,直到「catch」 - 很可能是在訪問第二個文件時壓制引發的異常。你應該能夠通過逐步使用調試來弄清楚什麼是錯的。 – Filburt 2015-04-02 07:32:15