繁体   English   中英

如何在C#中使用Excel-列名格式在Excel中获取列索引

[英]How to get column index in Excel using excel-column-name format in C#

我在这里http://lateral8.com/articles/2010/3/5/openxml-sdk-20-export-a-datatable-to-excel.aspx发现了一个很棒的功能

private string getColumnName(int columnIndex)
{
    int dividend = columnIndex;
    string columnName = String.Empty;
    int modifier;

    while (dividend > 0)
    {
        modifier = (dividend - 1) % 26;
        columnName = 
            Convert.ToChar(65 + modifier).ToString() + columnName;
        dividend = (int)((dividend - modifier) / 26);
    }

    return columnName;
}

我想做类似的事情-提供列名并接收索引。 例如,提供名称“ AB”并作为结果索引28接收。该怎么做?

更新:

令人惊讶的是,我在评论部分找到了解决方案

在这里https://stackoverflow.com/a/8739121/907732

和这里https://stackoverflow.com/a/4888750/907732

public static string GetColumnName(int index)
{
    const string letters = "ZABCDEFGHIJKLMNOPQRSTUVWXY";

    int NextPos = (index / 26);
    int LastPos = (index % 26);
    if (LastPos == 0) NextPos--;

    if (index > 26)
        return GetColumnName(NextPos) + letters[LastPos];
    else
        return letters[LastPos] + "";
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM