侧边栏壁纸
博主头像
进击的码农博主等级

新年新气象,开搞开搞

  • 累计撰写 31 篇文章
  • 累计创建 11 个标签
  • 累计收到 1 条评论

目 录CONTENT

文章目录

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

wosperry
2021-06-17 / 0 评论 / 0 点赞 / 6 阅读 / 867 字
/// <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;
}
0

评论区