2014-12-23 33 views
0

我想将包含十六进制值的CSV文件的内容添加到文本框并将每个字节输出到列表框。将CSV文件导入到文本框但没有正确格式化

单击添加文件按钮时,CSV文件的内容会显示在文本框中,每个字节用逗号分隔,但是当我点击写入按钮时,会引发异常。

“系统格式异常,其他不可分析的字符在字符串末尾”。

我不知道这是如何发生的,因为当用逗号分隔的其他十六进制值输入时,它工作得很好。格式在文本框中完全相同(例如AA,66,FF,EE),但似乎不适用于CSV文件?

private void AddFileSPI_Click(object sender, EventArgs e) 
    { 
     string AddFile = ""; 
     DialogResult result = openFile.ShowDialog(); 
     if (result == DialogResult.OK) 
     { 
      string file = openFile.FileName; 
      try 
      { 
       AddFile = File.ReadAllText(file); 
      } 
      catch (IOException ex) 
      { 
       MessageBox.Show(ex.Message); 
      } 
     } 
     Value.Text = AddFile; 
    } 


    private void Write_Click(object sender, EventArgs e) 
       { 
        string hex = Value.Text; 

         string[] hex1 = hex.Split(','); 
         byte[] bytes1 = new byte[hex1.Length]; 

         for (int j = 0; j < hex1.Length; j++) 
         { 
          bytes1[j] = Convert.ToByte(hex1[j], 16); 
          hexValues1.Add(bytes1[j]); 
          writebuff = hexValues1.ToArray(); 
          hexValue = writebuff[x].ToString("X2"); 
          WriteHexValues.Items.Add("0x" + hexValue); 
          x++; 
         } 
       } 
+0

也许您的CSV有一些数据不是十六进制值?把文件内容放在里面,以便我们看到它。 – Gusman

+0

我自己在Excel中进行测试,只包含5个十六进制值AA,FF,66,DD,FF,这是我添加CSV文件时出现在文本框中的内容。 – john

+0

粘贴文件的确切内容。 Excel倾向于为它添加一些标题,额外的信息,标题名称等。 – Gusman

回答

0

变化hex.Split( '');到

hex.Split(",\r\n".ToCharArray(), StringSplitOptions.RemoveEmptyEntries); 
0

删除空白:

for (int j = 0; j < hex1.Length; j++) 
{ 
    string fieldString = hex1[j].Trim(); 
    if(string.IsNullOrWhiteSpace(fieldString)) throw ... // or other error handling 
    bytes1[j] = Convert.ToByte(hex1[j], 16); 

应该帮助...