前提
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ページの「アクティブ」「注目」タブのフィードに表示されにくくなります。
質問の評価を下げたことを取り消します
この機能は開放されていません
評価を下げる条件を満たしてません
質問の評価を下げる機能の利用条件
この機能を利用するためには、以下の事項を行う必要があります。
- 質問回答など一定の行動
-
メールアドレスの認証
メールアドレスの認証
-
質問評価に関するヘルプページの閲覧
質問評価に関するヘルプページの閲覧
checkベストアンサー
0
CSV形式のファイルをDataTableや配列等として取得する
DataTable にして DataGridView の DataSource に突っ込めば表示されます。
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
15分調べてもわからないことは、teratailで質問しよう!
- ただいまの回答率 89.99%
- 質問をまとめることで、思考を整理して素早く解決
- テンプレート機能で、簡単に質問をまとめられる
質問への追記・修正、ベストアンサー選択の依頼
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