C#
定石1: NuGetでNewtonsoft.Jsonを入れる+最小コード
出典: C# Newtonsoft.Json で業務系JSON処理を実戦投入する完全ガイド(.NET Framework 4.7.2 編) — 定石1: NuGetでNewtonsoft.Jsonを入れる+最小コード
// ✅定石1:最小シリアライズ・デシリアライズ
using Newtonsoft.Json;
public class OrderDto
{
public int OrderId { get; set; }
public string CustomerName { get; set; }
public decimal Amount { get; set; }
public DateTime CreatedAt { get; set; }
}
//シリアライズ(オブジェクト→ JSON文字列)
var order = new OrderDto
{
OrderId = 1001,
CustomerName = "サンプル商事",
Amount = 12500m,
CreatedAt = DateTime.UtcNow,
};
string json = JsonConvert.SerializeObject(order);
// → {"OrderId":1001,"CustomerName":"サンプル商事","Amount":12500.0,"CreatedAt":"2026-05-09T05:00:00Z"}
//デシリアライズ(JSON文字列→オブジェクト)
string responseJson = HttpClient.GetString(apiUrl);
var parsed = JsonConvert.DeserializeObject<OrderDto>(responseJson);
Console.WriteLine($"{parsed.OrderId}: {parsed.CustomerName} {parsed.Amount}円");
▸ 実行ボタンで結果を表示
Source収録記事
この snippet は記事の「定石1: NuGetでNewtonsoft.Jsonを入れる+最小コード」セクションに登場する。コードの前後の文脈・ハマりどころの解説は記事本文で。
同じ記事から
5 件// ✅定石2:業務系ベース設定(プロジェクト全体で使い回す) public static class JsonConfig { public static readonly JsonSerializerSettings BusinessDefault = new JsonSerializerSettings未収録
定石2: JsonSerializerSettingsで業務系ベース設定を固定
#724e2bb51ad5
// ❌ NG:既定設定でKind=Localをシリアライズすると、ローカル時刻が出力される var bad = new { CreatedAt = DateTime.Now }; // Kind=Local string badJson = JsonConvert.SerializeObject(bad); // → {"CreatedAt":"2026-05-09T14:00:00+09:00"} ← JST環境のローカル時刻未収録
定石3: DateTimeのUTC統一で時刻ズレを潰す
#4610d44165e1
// ✅定石4:金額用カスタムJsonConverter(書き出し時に円マーク付与など) public class MoneyJsonConverter : JsonConverter<decimal> { public override void WriteJson(JsonWriter writer, decimal value, JsonSerializer serializer)未収録
定石4:カスタムJsonConverter —業務固有型の専用変換
#90fd64ac232b
// ✅定石5: JsonTextReaderで巨大JSONをストリーミング読み込み using (var fs = new FileStream(jsonFilePath, FileMode.Open, FileAccess.Read)) using (var sr = new StreamReader(fs)) using (var reader = new JsonTextReader(sr))未収録
定石5: JsonTextReaderでストリーミング読み込み
#15abeba39934
// ❌ NG: JObject経由でdouble化け(金額計算が事故る) string apiResponse = "{\"amount\": 12500.10}"; var jobj = Newtonsoft.Json.Linq.JObject.Parse(apiResponse);未収録
定石6: decimalがdoubleに化ける問題と対策
#4e944e9ff5db
