文字列形式の整数の配列があります:
var arr = new string[] { "1", "2", "3", "4" };
さらにプッシュするには、「実際の」整数の配列が必要です。
void Foo(int[] arr) { .. }
私はintをキャストしようとしましたが、もちろん失敗しました:
Foo(arr.Cast<int>.ToArray());
次にできること:
var list = new List<int>(arr.Length);
arr.ForEach(i => list.Add(Int32.Parse(i))); // maybe Convert.ToInt32() is better?
Foo(list.ToArray());
または
var list = new List<int>(arr.Length);
arr.ForEach(i =>
{
int j;
if (Int32.TryParse(i, out j)) // TryParse is faster, yeah
{
list.Add(j);
}
}
Foo(list.ToArray());
両方とも見苦しいです。
タスクを完了する他の方法はありますか?
配列を指定すると、 Array.ConvertAll
method を使用できます。
int[] myInts = Array.ConvertAll(arr, s => int.Parse(s));
ラムダを省略できることを指摘してくれたMarc Gravellに感謝します。これにより、以下に示す短いバージョンが生成されます。
int[] myInts = Array.ConvertAll(arr, int.Parse);
LINQソリューションも同様ですが、追加のToArray
呼び出しで配列を取得する必要があります。
int[] myInts = arr.Select(int.Parse).ToArray();
編集:配列に変換する
int[] asIntegers = arr.Select(s => int.Parse(s)).ToArray();
これでうまくいくはずです:
var asIntegers = arr.Select(s => int.Parse(s));
.Parse
での例外を回避するために、いくつかの.TryParse
の代替手段を以下に示します。
解析可能な要素のみを使用するには:
string[] arr = { null, " ", " 1 ", " 002 ", "3.0" };
int i = 0;
var a = (from s in arr where int.TryParse(s, out i) select i).ToArray(); // a = { 1, 2 }
または
var a = arr.SelectMany(s => int.TryParse(s, out i) ? new[] { i } : new int[0]).ToArray();
解析できない要素に0
を使用する代替方法:
int i;
var a = Array.ConvertAll(arr, s => int.TryParse(s, out i) ? i : 0); //a = { 0, 0, 1, 2, 0 }
または
var a = arr.Select((s, i) => int.TryParse(s, out i) ? i : 0).ToArray();
C#7. :
var a = Array.ConvertAll(arr, s => int.TryParse(s, out var i) ? i : 0);
あなたは単純に文字列配列をint配列にキャストすることができます:
var converted = arr.Select(int.Parse)
var asIntegers = arr.Select(s => int.Parse(s)).ToArray();
IEnumerable<int>
が返されないことを確認する必要があります
var list = arr.Select(i => Int32.Parse(i));