将 A 转换为 1 B 转换为 2 ... Z 转换为 26,然后将 AA 转换为 27 AB 转换为 28(Excel 中列引用的列索引)

Posted

技术标签:

【中文标题】将 A 转换为 1 B 转换为 2 ... Z 转换为 26,然后将 AA 转换为 27 AB 转换为 28(Excel 中列引用的列索引)【英文标题】:Convert A to 1 B to 2 ... Z to 26 and then AA to 27 AB to 28 (column indexes to column references in Excel) 【发布时间】:2009-12-23 09:01:39 【问题描述】:

有没有人有算法或逻辑将 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;

【讨论】:

+1 使用折叠。您甚至不需要将字符串转换为 char 数组,因为字符串的行为已经类似于 IEnumerable。例如。 s.Select(c => c - 'A' + 1).Aggregate((sum, next) => sum * 26 + next) 谢谢cfern。我忘记了字符串实现了 IEnumerable。我已经更新了答案 简洁的解决方案,但 Visual Studio 2005 不支持 Linq Brah... 你需要 ToCharArray() 3.5 b4 中的那个字符串你扔掉一个 Select @Merritt 我想包含 System.Linq 命名空间就足够了【参考方案2】:

看看这些

/// <summary>
/// 1 -> A<br/>
/// 2 -> B<br/>
/// 3 -> C<br/>
/// ...
/// </summary>
/// <param name="column"></param>
/// <returns></returns>
public static string ExcelColumnFromNumber(int column)

    string columnString = "";
    decimal columnNumber = column;
    while (columnNumber > 0)
    
        decimal currentLetterNumber = (columnNumber - 1) % 26;
        char currentLetter = (char)(currentLetterNumber + 65);
        columnString = currentLetter + columnString;
        columnNumber = (columnNumber - (currentLetterNumber + 1)) / 26;
    
    return columnString;


/// <summary>
/// A -> 1<br/>
/// B -> 2<br/>
/// C -> 3<br/>
/// ...
/// </summary>
/// <param name="column"></param>
/// <returns></returns>
public static int NumberFromExcelColumn(string column)

    int retVal = 0;
    string col = column.ToUpper();
    for (int iChar = col.Length - 1; iChar >= 0; iChar--)
    
        char colPiece = col[iChar];
        int colNum = colPiece - 64;
        retVal = retVal + colNum * (int)Math.Pow(26, col.Length - (iChar + 1));
    
    return retVal;

【讨论】:

是否有任何理由使用十进制作为 columnNumber 和 currentLetterNumber 的类型? 不,这只是我最初实现它的方式。您可以将其更改为整数。测试很快,看起来不错。【参考方案3】:

这是一段 javascript 代码,如果你喜欢在客户端完成的话

<script type="text/javascript" lang="javascript">
function Alphabet2Numeric(mystr) 
    mystr = mystr.toUpperCase(); //Hence the ASCII code 64 down there
    var sum = 0;
    for (var i = 0; i < mystr.length; i++) 
        sum = sum * 26 + mystr.charCodeAt(i) - 64; //returns 1 for 'a' and 2 for 'b' so on and so forth.
    
    return sum;

</script>

【讨论】:

【参考方案4】:

同样的问题,不同的语言:php

function charToInt($char)

   $array = array_flip(range(a, z));
   return $array[$char] + 1;


echo charToInt('c');

outputs: 3

【讨论】:

【参考方案5】:

从 A 到 ZZ : ((字符数 - 1) * 26 ) + 最后一个字符的 ASCII %65 + 第一个字符的 ASCII %65 * (26^(字符长度 -1)) -1 [仅当为正时添加]

【讨论】:

以上是关于将 A 转换为 1 B 转换为 2 ... Z 转换为 26,然后将 AA 转换为 27 AB 转换为 28(Excel 中列引用的列索引)的主要内容,如果未能解决你的问题,请参考以下文章

destring — 将字符串变量转换为数字变量,反之亦然

Python中字符串与数组的转换方法

php编程:将26位字母进制转换为10进制数字,如何做?

C++,如何将char型数组转换为string类型数组。

c++字符串如何转化为数字?

python + 进制的转换