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

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

ただいまの
回答率

89.99%

VB.NET ローカルファイルからCSVを読み込んでDataGridViewに表示させたい

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 831

layla

score 7

前提

VB.NET全くのド素人の者です。初めて質問させていただきます。

現在BMIの計算アプリを作っていまして、その計算結果などをdatagridviewに表示させ、保存ボタンを押すことでcsv形式でローカルに名前を付けて保存することができるようにしました。

教えていただきたいこと

そこで今度は逆に読み込みボタンを押してローカルに保存してあるcsvファイルを選択し、datagridviewに表示させる機能を付けたいのですが、どこのサイトを見てもやり方を見つけることが出来ませんでした。具体的なコードなどを教えていただけると幸いです。

追記
http://bbs.wankuma.com/index.cgi?mode=al2&namber=90559
時間がなかったため、こちらのサイトでも同時並行で同じアプリの質問をしていました。

Public Class Form1
    Private Sub btnClose_Click(sender As Object, e As EventArgs) Handles btnClose.Click
       Me.Close()  
  End Sub
    Private Sub btnBMI_Click(sender As Object, e As EventArgs) Handles btnBMI.Click

       Dim Height As Double = txtHeight.Text
        Dim Weight As Double = txtWeight.Text
        Dim Name As String = txtName.Text

       Dim BMI As Double
        If Height > 0 AndAlso Weight > 0 Then
            lblerror.Text = ""           BMI = Weight / ((Height / 100) * (Height / 100))
            txtBMI.Text = BMI.ToString("0.0")``` '有効数字以下は四捨五入される  

'肥満度判定  
If txtBMI.Text >= 25 Then  
lblHimando.Text = "肥満"           ElseIf txtBMI.Text < 25 AndAlso txtBMI.Text >= 18.5 Then  
lblHimando.Text = "普通"  
ElseIf txtBMI.Text < 18.5 Then  
lblHimando.Text = "痩せ"  
End If  

'肥満度によって文字の色を変更  
If lblHimando.Text = "肥満" Then  
lblHimando.ForeColor = Color.Red        ElseIf lblHimando.Text = "痩せ" Then  
lblHimando.ForeColor = Color.Blue  
End If  
'0以下が入力された時にエラーメッセージを表示  
Else            lblerror.Text = "正しい値を入力してください"  
lblHimando.Text = ""  
End If  
End Sub  
Private Sub DataGridView1_CellContentClick(sender As Object, e As DataGridViewCellEventArgs) Handles DataGridView1.CellContentClick  

End Sub  
Private Sub btnTouroku_Click(sender As Object, e As EventArgs) Handles btnTouroku.Click  
If txtBMI.Text = "" Then  
lblerror.Text = "計算してください"  
Else  
Dim idx As Integer = DataGridView1.Rows.Add()            DataGridView1.Rows(idx).Cells(0).Value = idx  
DataGridView1.Rows(idx).Cells(1).Value = txtName.Text  
DataGridView1.Rows(idx).Cells(2).Value = txtHeight.Text  
DataGridView1.Rows(idx).Cells(3).Value = txtWeight.Text  
DataGridView1.Rows(idx).Cells(4).Value = txtBMI.Text  




End If  
End Sub  

Private Sub txtName_TextChanged(sender As Object, e As EventArgs) Handles txtName.TextChanged  

End Sub  

Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load  

End Sub  
Private Sub Button2_Click(ByVal sender As System.Object,  
ByVal e As System.EventArgs) Handles Button2.Click  

CsvFileSave("BMIデータ.csv")  
End Sub  
Dim FileName As String  
Public Property OpenFileDialog1 As Object  

Private Sub CsvFileSave(ByVal SaveFileName As String)  

' 「名前を付けて保存」ダイアログを使う方法  
Using sfd As New SaveFileDialog  
sfd.FileName = "BMIデータ.csv"  
sfd.Filter = "CSV(*.csv)|*.csv"  
sfd.CheckPathExists = True  
sfd.OverwritePrompt = True  
If sfd.ShowDialog() <> Windows.Forms.DialogResult.OK Then  
Exit Sub  
End If  
FileName = sfd.FileName  
End Using  
CsvFileSave(FileName)  
End Sub  
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • SurferOnWww

    2019/03/19 10:49

    コードは ``` と ``` で囲ってください。インデントされて見やすくなりますので。

    キャンセル

  • SurferOnWww

    2019/03/20 10:13

    囲い方が間違ってます。以下のようにコートの一番最初の行の上と一番最後の行の下に ``` を追加するのです。

    ```
    Public Class Form1
    ・・・中略・・・
    End Class
    ```

    キャンセル

  • SurferOnWww

    2019/03/22 00:33

    わんくま掲示板とのマルチポストですよね。ここにもルールがあるのですよ。そういうのは止めませんか?
    https://teratail.com/help#posted-otherservice

    キャンセル

回答 1

checkベストアンサー

0

CSV形式のファイルをDataTableや配列等として取得する

DataTable にして DataGridView の DataSource に突っ込めば表示されます。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/03/21 22:24

    ご回答ありがとうございました。上手くdatagridviewに表示させることが出来ました。お世話になりました。

    キャンセル

  • 2019/03/22 00:33

    わんくま掲示板とのマルチポストですよね。ここにもルールがあるのですよ。そういうのは止めませんか?
    https://teratail.com/help#posted-otherservice

    キャンセル

  • 2019/03/22 00:40

    質問を編集して、マルチポストである旨を明記してリンクを貼り、またマルチポスト先にも同様の手続きをしてください。

    そしてどちらかで解決した場合には必ず双方に報告してください。これが最低限で、あとはマルチポスト先の規約やガイドラインを尊重してください。

    キャンセル

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

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

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