Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/308.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 将A转换为1 B转换为2。。。Z到26,然后AA到27 AB到28(列索引到Excel中的列引用)_C#_Numbers - Fatal编程技术网

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

C# 将A转换为1 B转换为2。。。Z到26,然后AA到27 AB到28(列索引到Excel中的列引用),c#,numbers,C#,Numbers,是否有任何一个算法或逻辑将A转换为1,B转换为2,Z到26,然后AA到27,AB到28等等 换句话说,将列索引转换为Excel中的列引用。看看这些 /// <summary> /// 1 -> A<br/> /// 2 -> B<br/> /// 3 -> C<br/> /// ... /// </summary> /// <param name="column"></param> /// &l

是否有任何一个算法或逻辑将A转换为1,B转换为2,Z到26,然后AA到27,AB到28等等

换句话说,将列索引转换为Excel中的列引用。

看看这些

/// <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;
}
//
///1->A
///2->B
///3->C
/// ... /// /// /// 公共静态字符串ExcelColumnFromNumber(int列) { 字符串columnString=“”; 十进制列数=列数; 而(列数>0) { 十进制currentLetterNumber=(columnNumber-1)%26; 字符currentLetter=(字符)(currentLetterNumber+65); columnString=currentLetter+columnString; columnNumber=(columnNumber-(currentLetterNumber+1))/26; } 返回列字符串; } /// ///A->1
///B->2
///C->3
/// ... /// /// /// 公共静态int NumberFromExcelColumn(字符串列) { int-retVal=0; string col=column.ToUpper(); 对于(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)); } 返回返回; }
下面是一个简单的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;
}

这是一个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>

函数Alphabet2Numeric(mystr){
mystr=mystr.toUpperCase();//因此下面的ASCII码是64
var总和=0;
对于(变量i=0;i
相同的问题,不同的语言:PHP

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

echo charToInt('c');

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

您为什么要使用decimal作为columnNumber和currentLetterNumber的类型?不,这只是我最初实现它的方式。您可以将其更改为ints。快速测试,看起来很好。使用折叠时+1。您甚至不需要将字符串转换为字符数组,因为字符串的行为已经类似于IEnumerable了。例如,
s.Select(c=>c-'A'+1)。聚合((总和,下一个)=>sum*26+next)
Thx cfern。我忘了字符串实现了IEnumerable。我已经更新了answerNeat解决方案,但visual studio 2005Brah不支持Linq。。。你需要在3.5B4中设置一个字符串Select@Merritt我想包含
System.Linq
名称空间就足够了