将 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 数组,因为字符串的行为已经类似于 IEnumerables.Select(c => c - 'A' + 1).Aggregate((sum, next) => sum * 26 + next)
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 中列引用的列索引)的主要内容,如果未能解决你的问题,请参考以下文章