ホームページ バックエンド開発 C++ C#でDataTableを「records」配列を含むJSON文字列に変換する方法?

C#でDataTableを「records」配列を含むJSON文字列に変換する方法?

Jan 21, 2025 pm 04:36 PM

How to Convert a DataTable to a JSON String with a

C# DataTable から JSON への変換: 目的の形式を実現する

このガイドでは、デフォルトの JSON オブジェクト形式を回避して、C# DataTable を特定の構造を持つ JSON 文字列に変換する方法を説明します。 ターゲット形式は、個々のレコード オブジェクトの「レコード」配列を含む JSON オブジェクトです。

手順:

  1. DataTable にデータを取り込む: まず、DataTable を作成し、データベース (またはその他のソース) からのデータをそれに取り込みます。

  2. JavaScriptSerializer を使用する: JavaScriptSerializer クラスを利用して JSON シリアル化を処理します。

  3. 辞書のリストの作成: DataTable の各行を辞書として保存するリストを作成します。

  4. 辞書の反復と生成: DataTable 内の各 DataRow をループします。各行について:

    • 新しい辞書を作成します。
    • DataTable 内の各 DataColumn を反復処理します。
    • 列名 (col.ColumnName) をキーとして、対応する列の値 (dr[col]) を値として辞書に追加します。
    • 完成した辞書を辞書のリストに追加します。
  5. リストのシリアル化: 最後に、JavaScriptSerializer を使用して辞書のリストをシリアル化し、「records」プロパティを持つ JSON オブジェクトでラップします。

コード例:

using System.Web.Script.Serialization;
using System.Data;
using System.Collections.Generic;

public string ConvertDataTableToJson()
{
    DataTable dataTable = new DataTable();
    // Fill dataTable with data from your database

    JavaScriptSerializer serializer = new JavaScriptSerializer();
    List<Dictionary<string, object>> records = new List<Dictionary<string, object>>();

    foreach (DataRow row in dataTable.Rows)
    {
        Dictionary<string, object> record = new Dictionary<string, object>();
        foreach (DataColumn column in dataTable.Columns)
        {
            record.Add(column.ColumnName, row[column]);
        }
        records.Add(record);
    }

    return serializer.Serialize(new { records = records });
}
ログイン後にコピー

この改訂されたコードは、DataTable を指定された JSON 形式に変換する明確で効率的な方法を提供し、各レコードが「レコード」配列内で適切に表現されるようにします。 必要な using ステートメントを忘れずに追加してください。

以上がC#でDataTableを「records」配列を含むJSON文字列に変換する方法?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C言語関数によって返される値の種類は何ですか?返品値を決定するものは何ですか? C言語関数によって返される値の種類は何ですか?返品値を決定するものは何ですか? Mar 03, 2025 pm 05:52 PM

C言語関数によって返される値の種類は何ですか?返品値を決定するものは何ですか?

GULC:Cライブラリはゼロから構築されています GULC:Cライブラリはゼロから構築されています Mar 03, 2025 pm 05:46 PM

GULC:Cライブラリはゼロから構築されています

c言語関数形式文字ケース変換手順 c言語関数形式文字ケース変換手順 Mar 03, 2025 pm 05:53 PM

c言語関数形式文字ケース変換手順

C言語関数の定義と呼び出しルールは何ですか、そして C言語関数の定義と呼び出しルールは何ですか、そして Mar 03, 2025 pm 05:53 PM

C言語関数の定義と呼び出しルールは何ですか、そして

メモリに保存されているC言語関数の返品値はどこにありますか? メモリに保存されているC言語関数の返品値はどこにありますか? Mar 03, 2025 pm 05:51 PM

メモリに保存されているC言語関数の返品値はどこにありますか?

明確な使用法とフレーズ共有 明確な使用法とフレーズ共有 Mar 03, 2025 pm 05:51 PM

明確な使用法とフレーズ共有

STL(ソート、検索、変換など)のアルゴリズムを効率的に使用するにはどうすればよいですか? STL(ソート、検索、変換など)のアルゴリズムを効率的に使用するにはどうすればよいですか? Mar 12, 2025 pm 04:52 PM

STL(ソート、検索、変換など)のアルゴリズムを効率的に使用するにはどうすればよいですか?

C標準テンプレートライブラリ(STL)はどのように機能しますか? C標準テンプレートライブラリ(STL)はどのように機能しますか? Mar 12, 2025 pm 04:50 PM

C標準テンプレートライブラリ(STL)はどのように機能しますか?

See all articles