DataGridView
からデータを取得してcsvファイルに書き込む次のコードがあります。csv ファイルには 5 つの列があります。ただし、選択したクライアントのデータのみをファイルに書き込む必要があり、クライアント名はコンボボックスから選択されます。以下のコードはすべてのデータグリッド値をファイルに書き込みますが、ClientName がコンボボックス値と等しい行のみを書き込みたいのですが、これを機能させることができません
// inventory export
private void btnExportShareClass_Click( object sender, EventArgs e)
{
//SET GRID
DataGridView gridIn ;
string outputFile = Inv_Export_savePath.Text;
gridIn = Inv_DataGrid;
//VAR holding client combobox
string Selected_Combo = Inv_ClientList_Export_Combobox.Text ;
//test to see if the DataGridView has any rows
if (gridIn.RowCount > 0)
{
string value = "";
DataGridViewRow dr = new DataGridViewRow();
StreamWriter swOut = new StreamWriter(outputFile);
//write header rows to csv
for (int i = 0; i <= gridIn.Columns.Count - 1; i++)
{
if (i > 0)
{
swOut.Write(",");
}
swOut.Write(gridIn.Columns[i].HeaderText);
}
swOut.WriteLine();
//write DataGridView rows to csv
for (int j = 0; j <= gridIn.Rows.Count - 1; j++)
{
if (j > 0)
{
swOut.WriteLine();
}
dr = gridIn.Rows[j];
for (int i = 0; i <= gridIn.Columns.Count - 1; i++)
{
if (i > 0)
{
swOut.Write(",");
}
value = dr.Cells[i].Value.ToString();
//replace comma's with spaces
value = value.Replace(',', ' ');
//replace embedded newlines with spaces
value = value.Replace(Environment.NewLine, " ");
swOut.Write(value);
}
}
swOut.Close();
}
}
for (int i = 0; i <= gridIn.Columns.Count - 1; i++)
{
if (i > 0)
{
gridIn.Rows[i].ToString().Contains(Inv_ClientList_Export_Combobox.Text );
swOut.Write(",");
}
value = dr.Cells[i].Value.ToString();
//replace comma's with spaces
value = value.Replace(',', ' ');
//replace embedded newlines with spaces
value = value.Replace(Environment.NewLine, " ");
swOut.Write(value);
}