web-dev-qa-db-ja.com

文字のインクリメント

Char'B 'に' C '、次に' D 'などを返す方法を尋ねる質問を見つけました。答えは非常に複雑で、ほとんどがやり過ぎでした。

単純にこれを使用しない理由:

char X='A';
X++

編集:それはAからZに行き、次は何ですか?

21
Loj

結果に満足している場合は、それで問題ありません。

通常、私がそのような質問を見たとき、彼らは「Z」から「AA」またはそのようなものに折り返したいと思っています-Excel列のように。明らかに、charをインクリメントするだけでは、それは行われません。「[」に移動します。

または、1文字以内であっても、有効な値の範囲が連続していない場合があります。明らかな例は16進数です。 「9」をインクリメントすると、おそらく必要だった「a」または「A」の代わりに「:」が得られます。望ましい順序が「Unicodeで提供されるもの」になることはめったにありません。

23
Jon Skeet

インクリメントしたいだけの場合:

Char x = 'A';
Char y = (Char)(Convert.ToUInt16(x) + 1);

ただし、Excelのような列が必要な場合:

    // (1 = A, 2 = B...27 = AA...703 = AAA...)
    public static string GetColNameFromIndex(int columnNumber)
    {
        int dividend = columnNumber;
        string columnName = String.Empty;
        int modulo;

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

        return columnName;
    }

    // (A = 1, B = 2...AA = 27...AAA = 703...)
    public static int GetColNumberFromName(string columnName)
    {
        char[] characters = columnName.ToUpperInvariant().ToCharArray();
        int sum = 0;
        for (int i = 0; i < characters.Length; i++)
        {
            sum *= 26;
            sum += (characters[i] - 'A' + 1);
        }
        return sum;
    }
36
kerrubin

おそらく、ZからAA、ala Perl、PHPへの移行も意図されているためです。

1