Net Core教程

Excel 列名转int索引(C#版)

本文主要是介绍Excel 列名转int索引(C#版),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
/// <summary>
/// 获取Excel实际列索引
/// </summary>
/// <param name="columnName">Excel列名</param>
/// <returns>int格式索引</returns>
public int GetColumnIndex(string columnName)
{
	int result = 0;
	// A-Z 转换成 0-25的数字,并反转
	int[] colReverse = Encoding.ASCII.GetBytes(columnName.ToUpper()).Select(x =>
	{
		int aIndex = Encoding.ASCII.GetBytes("A")[0];
		int zIndex = Encoding.ASCII.GetBytes("Z")[0];
		return x < aIndex || x > zIndex ? 
            throw new ArgumentException($"参数有误{nameof(columnName)}") : 
        		x - aIndex;
	}).Reverse().ToArray();

    // 当成26进制数,遍历计算
    for (int i = 0; i < colReverse.Count(); i++)
    {
        // 个位(0~25)  其他位(1~26)
        int vReal = colReverse[i] + (i == 0 ? 0 : 1);
        result += vReal * (int)Math.Pow(26, i);
    }
    return result;
}
这篇关于Excel 列名转int索引(C#版)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!