2012-02-02 66 views
2

我们有一个数据表“ST”有两列“字”,“二进制”获得“索引数组的范围之外”异常

void replace() 
    { 

     string s1="", s2="";    
     StreamReader streamReader; 
     streamReader = File.OpenText("C:\\text.txt"); 
     StreamWriter streamWriter = File.CreateText("C:\\sample1.txt"); 
     int x = st.Rows.Count; 
     // int i1 = 0;          
      // Now, read the entire file into a string 
      while ((line = streamReader.ReadLine()) != null) 
      { 
       for (int i = 0; i < x; i++) 
       { 

       s1 = Convert.ToString(st.Rows[i]["Word"]); 
       s2 = Convert.ToString(st.Rows[i]["Binary"]); 
       s2+="000"; 
       char[] delimiterChars = { ' ', '\t' }; 
       String[] words = line.Split(delimiterChars); 

        // Write the modification into the same file      
       String ab = words[i]; //exception occurs here 
       // Console.WriteLine(ab); 
       streamWriter.Write(ab.Replace(s1,s2));         
       }     
      } 
     streamReader.Close(); 
     streamWriter.Close(); 
    } 

我们得到的一个“索引范围之外的数组“异常。我们无法找到问题。在此先感谢

编辑: tnx给每个人谁帮助。 我这样做,它以某种方式工作:再次

void replace() 
    { 
     string s1 = "", s2 = ""; 
     StreamReader streamReader; 
     streamReader = File.OpenText("C:\\sample1.txt"); 
     StreamWriter streamWriter = File.CreateText("C:\\sample1.txt"); 
     int x = st.Rows.Count;   
     while ((line = streamReader.ReadLine()) != null) 
     { 
      char[] delimiterChars = { ' ', '\t' }; 
      String[] words = line.Split(delimiterChars); 
      foreach (string str in words) 
      { 

       s1 = str; 
       DataRow drow = st.Rows.Find(str); 
       if (drow != null) 
       { 
        index = st.Rows.IndexOf(drow); 
        s2 = Convert.ToString(st.Rows[index]["Binary"]); 
        // s2 += "000"; 
        // ab = words[i];       
        Console.WriteLine(s1); 
        Console.WriteLine(s2); 
        streamWriter.Write(str.Replace(s1, s2));         
       } 
       else 
        break; 
      }    
     } 
     streamReader.Close(); 
     streamWriter.Close(); 
    } 

TNX给大家。 问候, sagar

回答

0

如果你有一个假想的行“abcde”,例如你的文件的第一行,而你的数据库“st”包含10行,你可以循环这个过程10次,第6次你会遇到错误。第6步将字符串拆分为:{a,b,c,d,e},然后尝试获取第五个索引(基于零),该索引位于数组之外。

+0

那么我该如何避免它? PLZ帮助 – 2012-02-02 17:24:21

+0

@vidya如果我理解您的示例中的应用程序,您正在查找要替换为字符串的单词,然后将修改的字符串放回到文件中。首先,我会提升内部循环之外的所有步骤,分割字符串,而分隔符可以在for循环之外完成。然后在for循环中,您实际上需要查看拆分字符串中的每个单词以进行替换。这样做的一种方法是添加一个迭代每个拆分词的for循环。一个更容易和更直接的方法是使用列表和扩展方法 – GrayWizardx 2012-02-02 17:56:09

+0

我会尝试列表。谢谢你的帮助 – 2012-02-02 18:11:06

5

你基于我的方式是行数又名X而不是字符串数组的长度。因此,您可能有100行,但字符串仅分成5个字符串值。

2

i是您所在行的索引。

while ((line = streamReader.ReadLine()) != null) 
{ 
    for (int i = 0; i < x; i++) // say we are on line 20 

words包含该行上单词的数组。

String[] words = line.Split(delimiterChars); // say there are 3 words on line 20 

如果行中的单词少于行索引...则会出现越界异常。

String ab = words[i]; // trying to get to word 20 out of 3... 

你需要使用一个有效的索引值在该行的单词数 - 目前尚不清楚你想在你的代码来实现什么,所以我不能提供一个例子。

0

使用调试器,以查看linewords阵列中的内容,并将其与i的值进行比较。调试器是你最好的朋友。