A を 1 に、B を 2 に、...、Z を 26 に、そして AA を 27 に、AB を 28 に、などに変換するアルゴリズムまたはロジックを持っている人はいますか。
つまり、列インデックスを Excel の列参照に変換します。
ベストアンサー1
簡単な LINQ 式を次に示します。
static int TextToNumber(this string text) {
return text
.Select(c => c - 'A' + 1)
.Aggregate((sum, next) => sum*26 + next);
}
このテスト
Console.WriteLine(" A -> " + "A".TextToNumber());
Console.WriteLine(" B -> " + "B".TextToNumber());
Console.WriteLine(" Z -> " + "Z".TextToNumber());
Console.WriteLine("AA -> " + "AA".TextToNumber());
Console.WriteLine("AB -> " + "AB".TextToNumber());
次のような出力が生成されます:
A -> 1
B -> 2
Z -> 26
AA -> 27
AB -> 28
アップデート:以下は、.NET 2.0 をターゲットにした同じコードです。
static int TextToNumber(string text) {
int sum = 0;
foreach (char c in text) {
sum = sum*26 + c - 'A' + 1;
}
return sum;
}