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

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

ただいまの
回答率

87.78%

DataGridViewのデータをxmlに保存したい

解決済

回答 3

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 2,436

score 12

前提・実現したいこと

DataGridViewの数値をxmlに保存したいです。
DataGridViewの中にチェックボックスを表示したいため出来ればDataSetを使用しない方法で探していますが、チェックボックスの表示が可能であること、データの保存が可能である事の2点を満たせばどんな方法でも構いません。

お恥ずかしながら殆ど知識がなく調べるにもどんな単語で検索すれば良いかも分からない状態なので、もし可能でしたら参考URLなど貼っていただければとても嬉しいです……

該当のソースコード

先ずは此方を使用したのですが、間に繰り返し文を挟めないので任意の文章が入力出来ず。

//xmlファイルのPATH
string dir = System.AppDomain.CurrentDomain.BaseDirectory.TrimEnd('\\');
string updir = dir.Substring(0, dir.LastIndexOf(@"\bin") + 1);
//保存する
XElement root =
new XElement("node",
new XElement("sample",
new XElement("checkbox", 1),
new XElement("date", "2019/07/25"),
),
new XElement("sample",
new XElement("checkbox", 0),
new XElement("date", "2019/07/25"),
));
FileStream fs = new FileStream(updir + "data.xml", FileMode.Create);
root.Save(fs);
fs.Close();
fs.Dispose();


現在は此方を使用しているのですが、nodeの中に階層を作る方法が分からず行き詰っています……

//xmlファイルのPATH
string dir = System.AppDomain.CurrentDomain.BaseDirectory.TrimEnd('\\');
string updir = dir.Substring(0, dir.LastIndexOf(@"\bin") + 1);

var doc = new XmlDocument();
var sample = doc.CreateElement("sample");
doc.AppendChild(sample);

var checkbox = doc.CreateElement("checlbox");
submit.InnerText = "1";
sample.AppendChild(checlbox);

var date = doc.CreateElement("date");
date.InnerText = "2019/07/25";
sample.AppendChild(date);

doc.Save(updir + "data.xml");


希望としてはこのような内容のxmlファイルが生成されてくれると嬉しいです。

<?xml version="1.0" encoding="UTF-8"?>
<node>
  <sample>
    <checkbox>1</checkbox>
    <date>2019/07/25</date>
  </sample>
  <sample>
    <checkbox>0</checkbox>
    <date>2019/07/25</date>
  </sample>
</node>


例えば後者のコードを使う場合for文でこういう形で入力しようと考えています。

for(int i=0; i<dataGridView1.Rows.Count; i++){
var checkbox = doc.CreateElement("checlbox");
submit.InnerText = dataGridView1.Rows[i].Cells[0].Value;
sample.AppendChild(checlbox);

var date = doc.CreateElement("date");
date.InnerText = dataGridView1.Rows[i].Cells[1].Value;
sample.AppendChild(date);
}


何かよい方法をご存知でしたらお力お貸し頂ければ幸いです。

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

作成にはVisualStudioのWindowsフォームアプリケーションを使用しています。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 3

+3

チェックボックスの表示が可能であること、データの保存が可能である事の2点を満たせばどんな方法でも構いません。

↓ こういう感じですか?

イメージ説明

アプリの基本的な構成は、DataGridView ⇔ BindingSource ⇔ DataSet ⇔ XML ファイルとしています。

作り方の詳細は以下の記事を見てください。

XML ファイルを DataGridView に表示
http://surferonwww.info/BlogEngine/post/2019/04/26/show-content-of-xml-file-on-datagridview.aspx

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

+2

    [XmlRoot("node")]
    public class xmldata
    {
        [XmlElement("sample")]
        public List<sample> samples;
    }

    public class sample
    {
        public int checkbox { get; set; }
        public string date { get; set; }
    }


こんな感じのデータ定義で

List<sample> list = new List<sample>();

list.Add(new sample() { checkbox = 1, date = "2019/07/25" });
list.Add(new sample() { checkbox = 0, date = "2019/07/24" });
list.Add(new sample() { checkbox = 1, date = "2019/07/23" });
list.Add(new sample() { checkbox = 0, date = "2019/07/22" });

xmldata data = new xmldata();
data.samples = list;

//余計なNameSpaceを出力しないように
XmlSerializerNamespaces xmlSerializerNamespaces = new XmlSerializerNamespaces();
xmlSerializerNamespaces.Add(String.Empty, String.Empty);

using (FileStream tw = new FileStream(@"data.xml",FileMode.Create))
{
    //XMLにシリアライズ
    XmlSerializer mySerializer = new XmlSerializer(typeof(xmldata));

    mySerializer.Serialize(tw, data, xmlSerializerNamespaces);
}


こういうふうにシリアライズするとか

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

checkベストアンサー

+1

検索しただけですが、下記が参考になりそうです。
https://www.ipentec.com/document/csharp-xml-write-use-dom

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/07/25 20:37

    私の参考にしているものと同じ原理のコードを書いているサイトを貼っていただいて助かりました、おかげで貼っていただいたページを参考に修正するだけで思った通りの動作をするコードが完成しました!ありがとうございました!

    キャンセル

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

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

関連した質問

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