質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.37%

ボタンクリックイベント時にgrdListに表示されたセルを抽出したい

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 1,187

score 8

前提・実現したいこと

ボタンをクリックした際にgridviewに表示された表から選択した行(複数可)の内容をCSVに出力したい。

発生している問題・エラーメッセージ

1.Button1_Clickのイベントを起こした際にgrid内の選択されているセルを抜き出すという動作を行うことができない。
2.抜き出したセルの内容をstreamwriterに出力する部分に一部不具合がある

```  

### 該当のソースコード  
//load時にgrdListにSQLを表示  
private void Form1_Load(object sender, EventArgs e)  
{  
MySqlConnection MySQLcn;  
string sSQL = string.Empty;  
try  
{  
MySQLcn = new MySqlConnection(ConfigurationManager.ConnectionStrings["mysql"].ConnectionString);  
MySQLcn.Open();  


//ここにSQL文が入る  


MySqlDataAdapter da = new MySqlDataAdapter(sSQL, MySQLcn);  
DataTable dt = new DataTable();  

da.Fill(dt);  
grdList.DataSource = dt;  

//gridviewを最大化する  
grdList.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.Fill;  


grdList.SelectionMode = DataGridViewSelectionMode.FullRowSelect;  

//DataGridView1のセルを読み取り専用にする  
grdList.ReadOnly = true;  

MySQLcn.Close();  


}  
catch  
{  
MessageBox.Show("データ読み込みに失敗しました。", "エラー", MessageBoxButtons.OK, MessageBoxIcon.Error);  
return;  
}  
}  


private void Button1_Click(object sender, EventArgs e)  
{  
//1:ここでgrid内で選択したセルを持っていきたい  
}  


//csvへの書き込み  
using (StreamWriter sw = new StreamWriter(@"\出力test.csv", false,System.Text.Encoding.GetEncoding("shift_jis")))  
{  
while (セルの中身)  
{  

string row = string.Empty;  

//今回行数は15  
for (int i = 0; i < 15; i++)  
{  
row[i] = (セルの中身.IsDBNull(i)) ) ? "" : reader.GetString(i).ToString();  

if (0 == i)  
{  
row += (セルの中身.IsDBNull(i)) ? "" : reader.GetString(i).ToString();  
}  
else  
{  
row += (セルの中身.IsDBNull(i)) ? "," : "," + reader.GetString(i).ToString();  
}  
}  
sw.WriteLine(row);  
}  
}  

試したこと

補足情報(FW/ツールのバージョンなど)

visualstudio2019 
WindowsForms
.NET framework4.7.2

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • y_waiwai

    2019/10/24 18:11

    ちとコードが見づらいので、質問を編集し、<code>ボタン、出てきた’’’の枠の中にコードを貼り付けてください

    キャンセル

  • y.u

    2019/10/24 21:05

    申し訳ございません。修正いたしました

    キャンセル

  • Zuishin

    2019/10/24 21:21

    不具合以前に疑似コードですよねこれ。

    キャンセル

  • SurferOnWww

    2019/10/24 21:24 編集

    何を作っているのですか? ASP.NET Web Forms? Windows Forms? その他?
    gridview とは何ですか?
    開発環境(OS, .NET のバージョンなど)ぐらいは書けませんか?

    キャンセル

回答 1

checkベストアンサー

+3

あまり一度にしてはいけません。プログラミングの基本は小さな機能に分割することです。
あなたがやるべきことは、

  1. DataGridView からデータを取り出す
  2. データを CSV に成形する
  3. データをファイルに書き出す

以上の三つです。これをすべて同時に行うと、不具合がどこで起きているのか非常にわかりにくくなります。
したがって、確実に動作するよう一つずつ作っていきましょう。
まずはデータを取り出し、Debug.WriteLine で出力ウィンドウに出力して動作を確かめるもの、次にデータを CSV に成形して出力するもの、最後にそれをファイルに書き出すものです。

しかし、今回に限ってはもっと簡単な道があります。

var dataObject = dataGridView1.GetClipboardContent();
var csv = dataObject.GetText(TextDataFormat.CommaSeparatedValue);
Debug.WriteLine(csv);

ボタンを押すと上記コードが動くようにし、適当なセルを選択して動かしてみてください。CSV に成形された状態で出力されると思います。
DataGridView には、選択されたセルの中身を CSV として取り出す機能が内蔵されているのです。これは主にクリップボードにコピーする時に使うよう想定され、GetClipboardContent という名前になっています。

このメソッドによって取り出された DataObject 型のデータは、様々な形でデータを取り出せるようになっています。そのうち、TextDataFormat.CommaSeparatedValue を指定して取り出したデータは CSV になります。

これをファイルに書き込んでください。ファイルへの書き込みは、File.WriteAllText を使うと楽です。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/10/25 09:23

    ありがとうございます!解決できました

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.37%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る