Effectuez les opérations suivantes:
var r = File.ReadAllLines(path)
.Select(line => line.Split(' '))
.Select(arr => new
{
Column0 = Int32.Parse(arr[0]),
Column1 = Int32.Parse(arr[1])
// etc
})
.ToArray();
Puis:
int[] column0 = r.Select(x => x.Column0).ToArray(); // note double loop over r
int[] column1 = r.Select(x => x.Column1).ToArray();
ou plus long, mais aussi plus efficace:
int[] column0 = new int[r.Length], column1 = new int[r.Length];
for (int i = 0; i < r.Length; i++) // single loop over r
{
column0[i] = t[i].Column0;
column1[i] = t[i].Column1;
}
ou encore plus long, mais aussi (en parlant général) encore plus efficace:
List<int> column0 = new List<int>(), column1 = new List<int>();
using (Stream stream = File.Open(path, FileMode.Open))
using (TextReader sr = new StreamReader(stream, Encoding.UTF8))
{
string line;
while ((line = sr.ReadLine()) != null)
{
string[] arr = line.Split(' ');
column0.Add(Int32.Parse(arr[0]);
column1.Add(Int32.Parse(arr[1]);
}
}
Pour itérer/Résultat d'affichage (zéro à base d'index, à savoir la ligne 0, 1, etc.):
for (int i = 0; i < column0.Length; i++)
{
Console.WriteLine("Line {0}: column 0: {1}, column 1: {2}", i, column0[i], column1[i]);
}
Pour une meilleure fiabilité, utilisez une fonction au lieu de Int32.Parse:
static int Parse(string input)
{
int i;
if (!Int32.TryParse(intput, out i)
throw new Exception("Can't parse " + input);
return i;
}
Qu'avez-vous essayé jusqu'à présent? – ronen