He aquí una expresión LINQ simple:
static int TextToNumber(this string text) {
return text
.Select(c => c - 'A' + 1)
.Aggregate((sum, next) => sum*26 + next);
}
Esta prueba
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());
producirá esta salida:
A -> 1
B -> 2
Z -> 26
AA -> 27
AB -> 28
Actualización: Aquí está el mismo código, pero que apuntan a .NET 2.0:
static int TextToNumber(string text) {
int sum = 0;
foreach (char c in text) {
sum = sum*26 + c - 'A' + 1;
}
return sum;
}
funciona bien, gracias – Thunder
¿Hay alguna razón por la que está utilizando decimal como tipo para ColumnNumber y currentLetterNumber? – Matthias
No, esta es solo la forma en que originalmente lo implementé. Puedes cambiarlo a Ints. Probado rápido y parece estar bien. –