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)

后端 未结 4 665
刺人心
刺人心 2020-12-05 14:20

Does any one have algorithm or logic to Convert A to 1 ,B to 2, ... ,Z to 26 and then ,AA to 27, AB to 28 etc.

In other words, converting a column index into the col

相关标签:
4条回答
  • 2020-12-05 14:42

    Same problem, different language: PHP.

    function charToInt($char)
    {
       $array = array_flip(range(a, z));
       return $array[$char] + 1;
    }
    
    echo charToInt('c');
    
    outputs: 3
    
    0 讨论(0)
  • 2020-12-05 14:48

    Have a look at these

    /// <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;
    }
    
    0 讨论(0)
  • 2020-12-05 14:53

    This is a code for JavaScript if you prefer it done on the client side

    <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>
    
    0 讨论(0)
  • 2020-12-05 15:07

    Here's a simple LINQ expression:

    static int TextToNumber(this string text) {
        return text
            .Select(c => c - 'A' + 1)
            .Aggregate((sum, next) => sum*26 + next);
    }
    

    This test

    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());
    

    will produce this output:

     A -> 1
     B -> 2
     Z -> 26
    AA -> 27
    AB -> 28
    

    Update: Here's the same code but targetting .NET 2.0:

    static int TextToNumber(string text) {
        int sum = 0;
        foreach (char c in text) {
            sum = sum*26 + c - 'A' + 1;
        }
        return sum;
    }
    
    0 讨论(0)
提交回复
热议问题