C# EBCDIC到ASCII的转换。越界错误。在C中#

C# EBCDIC到ASCII的转换。越界错误。在C中#,c#,ascii,ebcdic,C#,Ascii,Ebcdic,我尝试使用这个通用转换顺序(如下所示)在C#中创建一个从EBCDIC到ASCII的转换器。基本上,程序将ASCII转换为等效整数,并使用以下顺序将其转换为EDCDIC 现在,当我尝试在C#中编译它,并尝试给出一个EBCDIC字符串(从另一台计算机的另一个文件获得)时,它显示了一些EBCDIC字符的“越界”异常。为什么会这样??是关于形成的吗??还是C#??还是窗户 额外:我尝试使用0..255数字的循环打印出所有ASCII和EBCDIC字符,但仍然没有显示许多EBCDIC字符。我是否缺少任何标准

我尝试使用这个通用转换顺序(如下所示)在C#中创建一个从EBCDIC到ASCII的转换器。基本上,程序将ASCII转换为等效整数,并使用以下顺序将其转换为EDCDIC

现在,当我尝试在C#中编译它,并尝试给出一个EBCDIC字符串(从另一台计算机的另一个文件获得)时,它显示了一些EBCDIC字符的“越界”异常。为什么会这样??是关于形成的吗??还是C#??还是窗户

额外:我尝试使用0..255数字的循环打印出所有ASCII和EBCDIC字符,但仍然没有显示许多EBCDIC字符。我是否缺少任何标准

整个代码如下:

public string convertFromEBCDICtoASCII(string inputEBCDICString, int initialPos, int endPos)
    {
        string inputSubString = inputEBCDICString.Substring(initialPos, endPos);
        int[] e2a = new int[256]{
                                    0, 1, 2, 3,156, 9,134,127,151,141,142, 11, 12, 13, 14, 15,
                                    16, 17, 18, 19,157,133, 8,135, 24, 25,146,143, 28, 29, 30, 31,
                                    128,129,130,131,132, 10, 23, 27,136,137,138,139,140, 5, 6, 7,
                                    144,145, 22,147,148,149,150, 4,152,153,154,155, 20, 21,158, 26,
                                    32,160,161,162,163,164,165,166,167,168, 91, 46, 60, 40, 43, 33,
                                    38,169,170,171,172,173,174,175,176,177, 93, 36, 42, 41, 59, 94,
                                    45, 47,178,179,180,181,182,183,184,185,124, 44, 37, 95, 62, 63,
                                    186,187,188,189,190,191,192,193,194, 96, 58, 35, 64, 39, 61, 34,
                                    195, 97, 98, 99,100,101,102,103,104,105,196,197,198,199,200,201,
                                    202,106,107,108,109,110,111,112,113,114,203,204,205,206,207,208,
                                    209,126,115,116,117,118,119,120,121,122,210,211,212,213,214,215,
                                    216,217,218,219,220,221,222,223,224,225,226,227,228,229,230,231,
                                    123, 65, 66, 67, 68, 69, 70, 71, 72, 73,232,233,234,235,236,237,
                                    125, 74, 75, 76, 77, 78, 79, 80, 81, 82,238,239,240,241,242,243,
                                    92,159, 83, 84, 85, 86, 87, 88, 89, 90,244,245,246,247,248,249,
                                    48, 49, 50, 51, 52, 53, 54, 55, 56, 57,250,251,252,253,254,255
                            };
        char chrItem = Convert.ToChar("0");
        StringBuilder sb = new StringBuilder();
        for (int i = 0; i < inputSubString.Length; i++)
        {
            try
            {
                chrItem = Convert.ToChar(inputSubString.Substring(i, 1));
                sb.Append(Convert.ToChar(e2a[(int)chrItem]));
                sb.Append((int)chrItem);
                sb.Append((int)00);
            }
            catch (Exception ex)
            {
                Console.WriteLine("//" + ex.Message);
                return string.Empty;
            }
        }
        string result = sb.ToString();
        sb = null;
        return result;
    }
public string convertFromEBCDICtoASCII(字符串输入ebcdicstring,int initialPos,int endPos)
{
字符串inputSubString=inputEBCDICString.Substring(initialPos,endPos);
int[]e2a=新int[256]{
0, 1, 2, 3,156, 9,134,127,151,141,142, 11, 12, 13, 14, 15,
16, 17, 18, 19,157,133, 8,135, 24, 25,146,143, 28, 29, 30, 31,
128,129,130,131,132, 10, 23, 27,136,137,138,139,140, 5, 6, 7,
144,145, 22,147,148,149,150, 4,152,153,154,155, 20, 21,158, 26,
32,160,161,162,163,164,165,166,167,168, 91, 46, 60, 40, 43, 33,
38,169,170,171,172,173,174,175,176,177, 93, 36, 42, 41, 59, 94,
45, 47,178,179,180,181,182,183,184,185,124, 44, 37, 95, 62, 63,
186,187,188,189,190,191,192,193,194, 96, 58, 35, 64, 39, 61, 34,
195, 97, 98, 99,100,101,102,103,104,105,196,197,198,199,200,201,
202,106,107,108,109,110,111,112,113,114,203,204,205,206,207,208,
209,126,115,116,117,118,119,120,121,122,210,211,212,213,214,215,
216,217,218,219,220,221,222,223,224,225,226,227,228,229,230,231,
123, 65, 66, 67, 68, 69, 70, 71, 72, 73,232,233,234,235,236,237,
125, 74, 75, 76, 77, 78, 79, 80, 81, 82,238,239,240,241,242,243,
92,159, 83, 84, 85, 86, 87, 88, 89, 90,244,245,246,247,248,249,
48, 49, 50, 51, 52, 53, 54, 55, 56, 57,250,251,252,253,254,255
};
char chrItem=Convert.ToChar(“0”);
StringBuilder sb=新的StringBuilder();
for(int i=0;i
您没有显示生成错误的代码,但是如果您使用该字符作为数组的索引,您应该知道C#使用Unicode(2字节)字符。字符代码可以一直到64k。这对你的阵列来说绝对是不可能的。

你完全不清楚你在做什么,因为你发布的只是阵列

但是,我有一个您可能想要使用的。它不能处理“移位”,但它是普通
系统.Text.Encoding
类的一个子类,因此您可以将它与
StreamReader
类一起使用。哦,还有各种不同的口味——基本上,所有的都列在清单中。你需要找到一个适合你的

  string convertFromEBCDICtoASCII(string inputEBCDICString, ...)
你一开始就走错了路。无法将包含EBCDIC的文件读入字符串。NET文本文件读取器将假定文件中的文本是以某种方式编码的。与StreamReader一样,默认情况下它将使用utf-8。如果无法在EBCDIC文件上正常工作,则会错误解释某些字符,并将其转换为大于等于256的Unicode代码点。这将破坏你的数组索引代码

您必须将输入参数更改为字节[]。使用FileStream或file.ReadAllBytes()读取文件

下一个问题是表对.NET字符串无效,它们是用utf-16编码的。例如,128不是ASCII码,也不编码有效的Unicode码点。不确定使用了什么代码页来构造表,可能是代码页1252。替换字节后,接下来必须使用Encoding.GetString()将代码页转换为Unicode

要以另一种方式杀死这条龙,请注意编码类已经支持EBCDIC代码页。查看Encoding.GetEncodings()方法的文档。您必须了解IBM代码页。您可以将正确的编码传递给StreamReader(String,encoding)构造函数,而不必编写任何代码。

我就是这样做的

    #region public static byte[] ConvertAsciiToEbcdic(byte[] asciiData)
    public static byte[] ConvertAsciiToEbcdic(byte[] asciiData)
    {

        // Create two different encodings.
        Encoding ascii = Encoding.ASCII;
        Encoding ebcdic = Encoding.GetEncoding("IBM037");

        //Retutn Ebcdic Data
        return Encoding.Convert(ascii, ebcdic, asciiData);

    }
    #endregion

    #region public static byte[] ConvertEbcdicToAscii(byte[] ebcdicData)
    public static byte[] ConvertEbcdicToAscii(byte[] ebcdicData)
    {
        // Create two different encodings.
        Encoding ascii = Encoding.ASCII;
        Encoding ebcdic = Encoding.GetEncoding("IBM037");

        //Retutn Ascii Data
        return Encoding.Convert(ebcdic, ascii, ebcdicData);
    }
    #endregion

如果您可以发布基于数组执行转换的代码,我们可以尝试获取有关您的问题的更多信息。我们已经发布了全部代码。谢谢你们的EBCDIC到ASCII表是从哪里来的?为什么要创建一个查找表,然后乱搞循环呢?C#支持EBCDIC开箱即用-请参阅@Frank的回答非常感谢您的帮助。这似乎就是问题所在。如果这对你有帮助,请将我的回答标记为答案。谢谢。Unicode字符不是2字节。它们是21位(如果您愿意,也可以是20.1位),并且有许多表示形式。我想你的意思是说C#“字符”实际上是UTF-16代码单元。