5

先感谢您!我正在编写一个应用程序来读取 txt 文件并写入 Excel。从小处着手,我只是想阅读第一行。

Console.WriteLine 正确输出字符串(字符之间有空格),但是当我尝试从字符串中提取字符时出现此错误:附加信息:索引和长度必须引用字符串中的位置。

while ((input = stream.ReadLine()) != null)
{
  //ACH HEADER LINE
  if (iCurRecLine == 0 && input.IndexOf(HeaderBeginKeyWord) >= 0)     
  {
    Console.WriteLine(input);

    RepDate = input.Substring(23, 6).Trim();
    RecordTypeCode = input.Substring(0, 1).Trim();
    PriorityCode = input.Substring(1, 2).Trim();
    ImmDestination = input.Substring(3, 10).Trim();
    ImmOrigin = input.Substring(13, 10).Trim();
    FileCreatedDate = input.Substring(23, 6).Trim();
    FileCreatedTime = input.Substring(29, 4).Trim();
    FileIDModifier = input.Substring(33, 1).Trim();
    RecordSize = input.Substring(34, 3).Trim();
    BlockingFactor = input.Substring(37, 2).Trim();
    FormatCode = input.Substring(39, 1).Trim();
    Destination = input.Substring(40, 23).Trim();
    Origin = input.Substring(63, 23).Trim();
    ReferenceCode = input.Substring(86, 8).Trim();
    ...
  }
}

我在哪里做错了?

4

1 回答 1

9

您正在阅读的文件内容似乎没有经过验证。

.SubString()抛出ArgumentOutOfRangeException如果startIndex plus length indicates a position not within this instance.

所以:

 RepDate = input.Substring(23, 6).Trim();

input如果仅包含 10 个字符,则很容易失败并抛出此异常。

于 2013-09-06T23:41:53.930 回答