我有一个看起来像这样的文本文件:
John,Gauthier,blue,May
Henry,Ford,Red,June
James,Bond,Orange,December
我想把它拆分成一个二维字符串数组,这样我就可以将每一行分开,然后分隔每个单词。例如:
mystring[0][0] = "John"
mystring[1][3] = "June"
mystring[2][2] = "Orange"
这就是我现在所做的:
string[] words = new string [100];
System.IO.StreamReader myfile = new System.IO.StreamReader("c:\\myfile.csv");
while (fichier.Peek() != -1)
{
i++;
words = myfile.ReadLine().Split(',');
}
我被困住了。我能够将它分成一维字符串数组,但不能分成二维字符串数组。我想我需要拆分两次;第一次使用'\ n',第二次使用','然后将这两者放在一起。
答案 0 :(得分:8)
这实际上是一个单行:
File.ReadLines("myfilename.txt").Select(s=>s.Split(',')).ToArray()
由于这是一个初学者问题,所以这是正在发生的事情:
File.ReadLines(filename)返回文本文件中所有行的集合
.Select是一个带函数的扩展方法
s => s.Split(',')是函数,它用所有逗号分割字符串s并返回一个字符串数组。
.ToArray()接受.Select创建的字符串数组的集合,并从中创建一个数组,这样就可以获得数组。
答案 1 :(得分:0)
试试这个
var str = File.ReadAllText("myfile.csv");
var arr = str.Split(new string[] {Environment.NewLine}, StringSplitOptions.RemoveEmptyEntries);
var multi = arr.Select(x => x.Split(',')).ToArray();
答案 2 :(得分:0)
尝试:
var First = new string [100];
var Sec = new string [100];
System.IO.StreamReader myfile = new System.IO.StreamReader("c:\\myfile.csv");
while (fichier.Peek() != -1)
{
i++;
var buff = myfile.ReadLine().Split(',');
First[i] = buff[0];
Sec[i] = buff[1];
}
其他想法,使用XML序列化程序来序列化您的hole对象。两个扩展:
public static void SaveAsXML(this Object A, string FileName)
{
var serializer = new XmlSerializer(A.GetType());
using (var textWriter = new StreamWriter(FileName))
{
serializer.Serialize(textWriter, A);
textWriter.Close();
}
}
public static void LoadFromXML(this Object A, string FileName)
{
if (File.Exists(FileName))
{
using (TextReader textReader = new StreamReader(FileName))
{
XmlSerializer deserializer = new XmlSerializer(A.GetType());
A = (deserializer.Deserialize(textReader));
}
}
}
添加比任何静态类并调用:
YourSaveClassWhitchContainsYourArray.SaveAsXML("Datastore.xml");
或
YourSaveClassWhitchContainsYourArray.LoadFromXML("Datastore.xml");