.NET 8-разрядное Кодирование

Вы также можете использовать агрегат:

db.accommodations.aggregate(
[
     {$project: {_id:1, name:1, zipcode:1, 
                 size_of_name: {$size: "$name"}
                }
     },
     {$match: {"size_of_name": {$gt: 1}}}
])

// вы добавляете «size_of_name» для переноса документа и используете его для фильтрации размера имени

5
задан faulty 21 September 2008 в 17:21
поделиться

5 ответов

Латинский 1 иначе ISO-8859-1 иначе кодовая страница 28591 является полезной кодовой страницей для этого сценария, поскольку это отображает значения в диапазоне 128-255 неизменных. Следующее является взаимозаменяемым:

Encoding.GetEncoding(28591)
Encoding.GetEncoding("Latin1")
Encoding.GetEncoding("iso-8859-1")

Следующий код иллюстрирует то, это для Latin1, в отличие от Кодирования. Значение по умолчанию, все символы в диапазоне 0-255 отображаются неизменные:

static void Main(string[] args)
{

    Console.WriteLine("Test Default Encoding returned {0}", TestEncoding(Encoding.Default));
    Console.WriteLine("Test Latin1 Encoding returned {0}", TestEncoding(Encoding.GetEncoding("Latin1")));
    Console.ReadLine();
    return;
}

private static bool CompareBytes(char[] chars, byte[] bytes)
{
    bool result = true;
    if (chars.Length != bytes.Length)
    {
        Console.WriteLine("Length mismatch {0} bytes and {1} chars" + bytes.Length, chars.Length);
        return false;
    }
    for (int i = 0; i < chars.Length; i++)
    {
        int charValue = (int)chars[i];
        if (charValue != (int)bytes[i])
        {
            Console.WriteLine("Byte at index {0} value {1:X4} does not match char {2:X4}", i, (int) bytes[i], charValue);
            result = false;
        }
    }
    return result;
}
private static bool TestEncoding(Encoding encoding)
{
    byte[] inputBytes = new byte[256];
    for (int i = 0; i < 256; i++)
    {
        inputBytes[i] = (byte) i;
    }

    char[] outputChars = encoding.GetChars(inputBytes);
    Console.WriteLine("Comparing input bytes and output chars");
    if (!CompareBytes(outputChars, inputBytes)) return false;

    byte[] outputBytes = encoding.GetBytes(outputChars);
    Console.WriteLine("Comparing output bytes and output chars");
    if (!CompareBytes(outputChars, outputBytes)) return false;

    return true;
}
15
ответ дан 18 December 2019 в 06:24
поделиться

Я думаю, что необходимо использовать массив байтов вместо этого. Для сравнения можно использовать некоторый метод как это:

static bool CompareRange(byte[] a, byte[] b, int index, int count)
{
    bool res = true;
    for(int i = index; i < index + count; i++)
    {
        res &= a[i] == b[i];
    }
    return res;
}
2
ответ дан 18 December 2019 в 06:24
поделиться

Почему не только используют массив байтов вместо этого? Это не имело бы ни одной из проблем кодирования, которые Вы, вероятно, перенесете с текстовым подходом.

9
ответ дан 18 December 2019 в 06:24
поделиться

Вы могли использовать кодирование base64 для преобразования из байта, чтобы представить в виде строки и отступить. Никакие проблемы с кодовыми страницами или странными символами тот путь, и это будет более эффективно пространством, чем шестнадцатеричное число.

byte[] toEncode; 
string encoded = System.Convert.ToBase64String(toEncode);
-2
ответ дан 18 December 2019 в 06:24
поделиться

Используйте еврейскую кодовую страницу для Windows 1255. Его 8 битов.
Кодирование enc = Кодирование. GetEncoding ("окна 1255");

Я missunderstod Вы, когда Вы записали "1-255", думали Вы где refereing к символам в кодовой странице 1255.

1
ответ дан 18 December 2019 в 06:24
поделиться
Другие вопросы по тегам:

Похожие вопросы: