dr = dt.NewRow(); dr[0] = this.tbxName1.Text; dr[1] = 1000; dr[2] = 1000; dr[3] = 1000; dt.Rows.Add(dr); dataGridView1.DataSource = dt;通过这样的方式将数据显示在dataGridView1中,并通过保存按钮保存在xml文件中,每次tbxName1变化时,xml文件都不覆盖上一次的内容,并且将每一次的tbxName1都写在下拉框中,点击下拉框里的tbxName1将xml中想对应的tbxName1内容显示在 dataGridView1中,然后通过提交按钮获取到这次datagridview1的数据
时间: 2024-03-03 07:48:15 浏览: 61
如果您想要实现每次保存时不覆盖上一次的内容,可以在保存时使用追加模式(Append mode)打开文件进行写入,而不是使用默认的写入模式(Write mode)。这可以通过以下代码实现:
```csharp
// 以追加模式打开文件进行写入
StreamWriter sw = new StreamWriter("data.xml", true);
// 将DataTable中的数据写入文件中
foreach (DataRow row in dt.Rows)
{
sw.WriteLine(row[0].ToString() + "," + row[1].ToString() + "," + row[2].ToString() + "," + row[3].ToString());
}
// 关闭文件流
sw.Close();
```
如果您想要将每一次的tbxName1都写在下拉框中,可以在保存时读取已有的xml文件,并将其中的tbxName1加入到下拉框中。这可以通过以下代码实现:
```csharp
// 读取已有的xml文件
if (File.Exists("data.xml"))
{
XDocument xdoc = XDocument.Load("data.xml");
// 将xml中的tbxName1加入到下拉框中
foreach (XElement element in xdoc.Descendants("row"))
{
string name = element.Element("name").Value;
if (!comboBox1.Items.Contains(name))
{
comboBox1.Items.Add(name);
}
}
}
// 将当前的tbxName1加入到下拉框中
if (!comboBox1.Items.Contains(this.tbxName1.Text))
{
comboBox1.Items.Add(this.tbxName1.Text);
}
```
最后,如果您想要实现在下拉框中选择tbxName1后将其对应的数据显示在DataGridView中,可以在下拉框的SelectedIndexChanged事件中读取xml文件,并筛选出对应的数据,然后将其绑定到DataGridView中。这可以通过以下代码实现:
```csharp
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
// 读取xml文件
XDocument xdoc = XDocument.Load("data.xml");
// 筛选出对应的数据
var rows = from element in xdoc.Descendants("row")
where element.Element("name").Value == comboBox1.SelectedItem.ToString()
select new
{
Name = element.Element("name").Value,
Column1 = element.Element("column1").Value,
Column2 = element.Element("column2").Value,
Column3 = element.Element("column3").Value
};
// 将筛选出的数据绑定到DataGridView中
dataGridView1.DataSource = rows.ToList();
}
```
最后,如果您想要在提交按钮中获取DataGridView中的数据,可以通过以下代码实现:
```csharp
foreach (DataGridViewRow row in dataGridView1.Rows)
{
string name = row.Cells[0].Value.ToString();
int column1 = int.Parse(row.Cells[1].Value.ToString());
int column2 = int.Parse(row.Cells[2].Value.ToString());
int column3 = int.Parse(row.Cells[3].Value.ToString());
// 在这里处理获取到的数据
}
```
阅读全文