0
FileStream fs = new FileStream(@"file.txt", FileMode.Create);
StreamWriter streamwriter = new StreamWriter(fs);

try
{
    for (int j = 0; j < dataGridView1.Rows.Count -1 ; j++)
    {
        for (i = 0; i < dataGridView1.Rows[j].Cells.Count; i++)
        {
            streamwriter.Write(dataGridView1.Rows[j].Cells[i].Value + "#");
        }

        streamwriter.WriteLine("\n");
    }

    streamwriter.Close();
    fs.Close();
    MessageBox.Show("File saved successfully!");
}
catch
{
    MessageBox.Show("File save failed!");
}

此函数应将值从 传输DataGridView到文件,但最后一个值不会不断写入。我意识到它删除了我输入的最后一个元素

它应该是这样的:

Name1#Lastname1#Number1#Home1#

这是真实的结果:

Name2#Lastname2#Number2##

4

2 回答 2

1

问题在于您的循环遍历行,现在您的条件是

j < dataGridView1.Rows.Count -1

这意味着如果行数为 10,您的循环将遍历索引 0 到 8,并跳过索引 9。

你应该改变你的条件

j < dataGridView1.Rows.Count

于 2020-09-21T09:57:28.183 回答
0

发布的代码将“如果”DataGridView’s属性AllowUsersToAddRows设置为true. 如果设置为false,则发布的代码将错过网格中的最后一行。

此外,根据网格DataSource,数据源本身可能不允许新行或被结构化以添加新行。在这种情况下,AllowUsersToAddRows属性变得无关紧要,但是在任何一种情况下……发布的代码仍然会错过最后一行。

由于代码在技术上是正确的“IF”,因此网格的AllowUsersToAddRows属性设置为true. 而且,您的问题似乎是关于“缺失”的最后一行……我假设 gridsAllowUsersToAddRows属性设置为false或数据源不允许添加新行。

为了避免这个问题……我建议在行循环中额外检查这个“新”行。如果您在行循环中检查“新”行,则 gridsAllowUsersToAddRows属性是true还是无关紧要false。此外,在行和单元格中使用foreach循环可能会使事情变得更容易,并且可能看起来像……</p>

foreach (DataGridViewRow row in dataGridView1.Rows) {
  if (!row.IsNewRow) {
    foreach (DataGridViewCell cell in row.Cells) {
      streamwriter.Write(cell.Value + "#");
    }
    streamwriter.WriteLine("");
  }
}
于 2020-09-21T11:47:31.713 回答