跳至页脚内容
.NET 帮助

Newtonsoft Jsonpath(开发者如何使用)

如果您曾经在.NET中使用过JSON数据,您可能遇到过Newtonsoft.Json库,这是一个.NET的高性能JSON框架。 本教程旨在帮助初学者和中级用户有效地理解和使用这个强大的库,重点介绍其系统引用、文档以及任何相关的版本更新。

开始

要开始使用Newtonsoft.Json,您首先需要将其安装到您的.NET项目中。 这可以通过NuGet,.NET包管理器来完成。 在NuGet包管理器控制台中,输入:

Install-Package Newtonsoft.Json

成功安装后,通过添加以下using语句将库添加到您的.NET项目中:

using Newtonsoft.Json;
using Newtonsoft.Json;
Imports Newtonsoft.Json
$vbLabelText   $csharpLabel

使用Newtonsoft.JSON解析JSON

解析JSON基本上是将JSON格式的字符串转换为您.NET应用程序中可用的数据结构的过程。 使用Newtonsoft.Json,该过程非常简单。

让我们来看一个有关人员的JSON对象示例:

{
    "Name": "Iron Developer",
    "Age": 30,
    "Email": "irondeveloper@ironsoftware.com"
}

我们可以使用JsonConvert.DeserializeObject<T>()方法将这个JSON字符串解析为C#对象,其中T是我们要创建的对象类型。 在这种情况下,我们将创建一个Person类并解析JSON到其中。

public class Person
{
    public string Name { get; set; }
    public int Age { get; set; }
    public string Email { get; set; }
}

string jsonString = "JSON string here";
Person person = JsonConvert.DeserializeObject<Person>(jsonString);
public class Person
{
    public string Name { get; set; }
    public int Age { get; set; }
    public string Email { get; set; }
}

string jsonString = "JSON string here";
Person person = JsonConvert.DeserializeObject<Person>(jsonString);
Public Class Person
	Public Property Name() As String
	Public Property Age() As Integer
	Public Property Email() As String
End Class

Private jsonString As String = "JSON string here"
Private person As Person = JsonConvert.DeserializeObject(Of Person)(jsonString)
$vbLabelText   $csharpLabel

现在,person对象将包含来自JSON字符串的值。

处理JSON文件

您通常需要从文件中读取或写入JSON数据。让我们看看如何使用Newtonsoft.Json来做到这一点。 在这种情况下,我们将使用System.IO命名空间中的File类。

要读取JSON文件并将其解析为对象:

string path = "path to your json file";
string jsonString = File.ReadAllText(path);
Person person = JsonConvert.DeserializeObject<Person>(jsonString);
string path = "path to your json file";
string jsonString = File.ReadAllText(path);
Person person = JsonConvert.DeserializeObject<Person>(jsonString);
Dim path As String = "path to your json file"
Dim jsonString As String = File.ReadAllText(path)
Dim person As Person = JsonConvert.DeserializeObject(Of Person)(jsonString)
$vbLabelText   $csharpLabel

要将对象写入JSON文件:

Person person = new Person() 
{
    Name = "John Doe",
    Age = 30,
    Email = "johndoe@example.com"
};

string path = "path to your json file";
string jsonString = JsonConvert.SerializeObject(person);
File.WriteAllText(path, jsonString);
Person person = new Person() 
{
    Name = "John Doe",
    Age = 30,
    Email = "johndoe@example.com"
};

string path = "path to your json file";
string jsonString = JsonConvert.SerializeObject(person);
File.WriteAllText(path, jsonString);
Dim person As New Person() With {
	.Name = "John Doe",
	.Age = 30,
	.Email = "johndoe@example.com"
}

Dim path As String = "path to your json file"
Dim jsonString As String = JsonConvert.SerializeObject(person)
File.WriteAllText(path, jsonString)
$vbLabelText   $csharpLabel

处理数组

在某些情况下,您的JSON会包含数组。 例如,一个Person对象可能有一个Friends数组:

{
    "Name": "John Doe",
    "Friends": [
        {
            "Name": "Jane Doe",
            "Age": 28
        },
        {
            "Name": "Billy",
            "Age": 25
        }
    ]
}

您可以使用foreach循环来遍历JSON数组:

JArray friends = (JArray)jsonObject["Friends"];
foreach (JObject friend in friends)
{
    string friendName = (string)friend["Name"];
    Console.WriteLine(friendName);
}
JArray friends = (JArray)jsonObject["Friends"];
foreach (JObject friend in friends)
{
    string friendName = (string)friend["Name"];
    Console.WriteLine(friendName);
}
Dim friends As JArray = CType(jsonObject("Friends"), JArray)
For Each [friend] As JObject In friends
	Dim friendName As String = CStr([friend]("Name"))
	Console.WriteLine(friendName)
Next [friend]
$vbLabelText   $csharpLabel

注意:jsonObject 应替换为实际从JSON初始化的JObject。

修改和写入JSON

Newtonsoft.Json使得修改和写入JSON变得简单。 假设您需要更新我们的Person对象的Age值。

jsonObject["Age"] = 31; // Update the age
jsonObject["Age"] = 31; // Update the age
jsonObject("Age") = 31 ' Update the age
$vbLabelText   $csharpLabel

然后将其写回字符串:

string updatedJson = jsonObject.ToString();
File.WriteAllText(path, updatedJson); // Write back to the file
string updatedJson = jsonObject.ToString();
File.WriteAllText(path, updatedJson); // Write back to the file
Dim updatedJson As String = jsonObject.ToString()
File.WriteAllText(path, updatedJson) ' Write back to the file
$vbLabelText   $csharpLabel

注意:jsonObject 应替换为实际从JSON初始化的JObject。

LINQ到JSON

Newtonsoft.Json还提供了使用LINQ(语言集成查询)查询和操作JSON对象的功能。 这是非常强大的,因为它允许您使用所有标准的LINQ操作符来查询JSON对象,就像您对XML或对象集合所做的那样。

这是一个示例,展示了如何获取所有Friends小于30岁的人的姓名:

var youngFriends = jsonObject["Friends"].Where(f => (int)f["Age"] < 30)
                                        .Select(f => (string)f["Name"]);
foreach (string name in youngFriends)
{
    Console.WriteLine(name);
}
var youngFriends = jsonObject["Friends"].Where(f => (int)f["Age"] < 30)
                                        .Select(f => (string)f["Name"]);
foreach (string name in youngFriends)
{
    Console.WriteLine(name);
}
Imports System

Dim youngFriends = jsonObject("Friends").Where(Function(f) CInt(Math.Truncate(f("Age"))) < 30).Select(Function(f) CStr(f("Name")))
For Each name As String In youngFriends
	Console.WriteLine(name)
Next name
$vbLabelText   $csharpLabel

注意:jsonObject 应替换为实际从JSON初始化的JObject。

IronPDF简介

Learn about IronPDF is a popular library in the .NET ecosystem that allows developers to 创建、编辑和提取PDF文件中的数据。 它非常多功能并且可以无缝地与其他库一起工作,包括Newtonsoft.Json。

IronPDF在HTML到PDF转换方面表现出色,确保精确保留原始布局和样式。 它非常适合从基于Web的内容中创建PDF,如报告、发票和文档。 利用对HTML文件、URL和原始HTML字符串的支持,IronPDF轻松生成高质量的PDF文档。

using IronPdf;

class Program
{
    static void Main(string[] args)
    {
        var renderer = new ChromePdfRenderer();

        // 1. Convert HTML String to PDF
        var htmlContent = "<h1>Hello, IronPDF!</h1><p>This is a PDF from an HTML string.</p>";
        var pdfFromHtmlString = renderer.RenderHtmlAsPdf(htmlContent);
        pdfFromHtmlString.SaveAs("HTMLStringToPDF.pdf");

        // 2. Convert HTML File to PDF
        var htmlFilePath = "path_to_your_html_file.html"; // Specify the path to your HTML file
        var pdfFromHtmlFile = renderer.RenderHtmlFileAsPdf(htmlFilePath);
        pdfFromHtmlFile.SaveAs("HTMLFileToPDF.pdf");

        // 3. Convert URL to PDF
        var url = "http://ironpdf.com"; // Specify the URL
        var pdfFromUrl = renderer.RenderUrlAsPdf(url);
        pdfFromUrl.SaveAs("URLToPDF.pdf");
    }
}
using IronPdf;

class Program
{
    static void Main(string[] args)
    {
        var renderer = new ChromePdfRenderer();

        // 1. Convert HTML String to PDF
        var htmlContent = "<h1>Hello, IronPDF!</h1><p>This is a PDF from an HTML string.</p>";
        var pdfFromHtmlString = renderer.RenderHtmlAsPdf(htmlContent);
        pdfFromHtmlString.SaveAs("HTMLStringToPDF.pdf");

        // 2. Convert HTML File to PDF
        var htmlFilePath = "path_to_your_html_file.html"; // Specify the path to your HTML file
        var pdfFromHtmlFile = renderer.RenderHtmlFileAsPdf(htmlFilePath);
        pdfFromHtmlFile.SaveAs("HTMLFileToPDF.pdf");

        // 3. Convert URL to PDF
        var url = "http://ironpdf.com"; // Specify the URL
        var pdfFromUrl = renderer.RenderUrlAsPdf(url);
        pdfFromUrl.SaveAs("URLToPDF.pdf");
    }
}
Imports IronPdf

Friend Class Program
	Shared Sub Main(ByVal args() As String)
		Dim renderer = New ChromePdfRenderer()

		' 1. Convert HTML String to PDF
		Dim htmlContent = "<h1>Hello, IronPDF!</h1><p>This is a PDF from an HTML string.</p>"
		Dim pdfFromHtmlString = renderer.RenderHtmlAsPdf(htmlContent)
		pdfFromHtmlString.SaveAs("HTMLStringToPDF.pdf")

		' 2. Convert HTML File to PDF
		Dim htmlFilePath = "path_to_your_html_file.html" ' Specify the path to your HTML file
		Dim pdfFromHtmlFile = renderer.RenderHtmlFileAsPdf(htmlFilePath)
		pdfFromHtmlFile.SaveAs("HTMLFileToPDF.pdf")

		' 3. Convert URL to PDF
		Dim url = "http://ironpdf.com" ' Specify the URL
		Dim pdfFromUrl = renderer.RenderUrlAsPdf(url)
		pdfFromUrl.SaveAs("URLToPDF.pdf")
	End Sub
End Class
$vbLabelText   $csharpLabel

假设我们有一个要求,需要从JSON数据中创建一份PDF报告。 我们可以使用Newtonsoft.Json来解析JSON数据,并使用IronPDF来创建PDF。 让我们看看如何做到这一点。

Installation of IronPDF

像Newtonsoft.Json一样,IronPDF也可以通过NuGet获得。 您可以使用以下命令安装它:

Install-Package IronPdf

然后通过添加:将其包含在您的项目中

using IronPdf;
using IronPdf;
Imports IronPdf
$vbLabelText   $csharpLabel

用例1:从JSON数据创建PDF

在此用例中,我们将演示如何使用Newtonsoft.Json和IronPDF从JSON数据生成PDF报告。 对于那些基于JSON格式存储的数据创建动态报告的应用程序,这可能特别有用。

这是我们将要处理的JSON文件的示例:

{
    "Title": "Sales Report",
    "Month": "August",
    "Year": "2023",
    "TotalSales": "10000",
    "ItemsSold": "500"
}

此JSON数据代表一个简单的销售报告。

第一步是读取名为'data.json'的JSON文件,并使用Newtonsoft.Json将其解析为字典:

string jsonString = File.ReadAllText("data.json");
var reportData = JsonConvert.DeserializeObject<Dictionary<string, string>>(jsonString);
string jsonString = File.ReadAllText("data.json");
var reportData = JsonConvert.DeserializeObject<Dictionary<string, string>>(jsonString);
Dim jsonString As String = File.ReadAllText("data.json")
Dim reportData = JsonConvert.DeserializeObject(Of Dictionary(Of String, String))(jsonString)
$vbLabelText   $csharpLabel

执行此代码后,您将拥有一个名为reportData的字典,其中包含表示JSON文件中属性及其值的键值对。

接下来,我们使用来自reportData的数据生成一个HTML模板。 从reportData字典中提取键以将适当的值插入HTML中:

string htmlContent = $@"
<html>
<head><title>{reportData["Title"]}</title></head>
<body>
    <h1>{reportData["Title"]}</h1>
    <p>Month: {reportData["Month"]}</p>
    <p>Year: {reportData["Year"]}</p>
    <p>Total Sales: {reportData["TotalSales"]}</p>
    <p>Items Sold: {reportData["ItemsSold"]}</p>
</body>
</html>";
string htmlContent = $@"
<html>
<head><title>{reportData["Title"]}</title></head>
<body>
    <h1>{reportData["Title"]}</h1>
    <p>Month: {reportData["Month"]}</p>
    <p>Year: {reportData["Year"]}</p>
    <p>Total Sales: {reportData["TotalSales"]}</p>
    <p>Items Sold: {reportData["ItemsSold"]}</p>
</body>
</html>";
Dim htmlContent As String = $"
<html>
<head><title>{reportData("Title")}</title></head>ignoreignore<body><h1>{reportData("Title")}</h1><p>Month: {reportData("Month")}</p><p>Year: {reportData("Year")}</p><p>Total Sales: {reportData("TotalSales")}</p><p>Items Sold: {reportData("ItemsSold")}</p></body></html>"
$vbLabelText   $csharpLabel

最后,我们使用IronPDF将HTML代码转换为PDF文档。 我们使用ChromePdfRenderer来创建PDF渲染器,使用它将HTML转换为PDF,然后保存PDF:

var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(htmlContent);
pdf.SaveAs("Report.pdf");
var renderer = new ChromePdfRenderer();
var pdf = renderer.RenderHtmlAsPdf(htmlContent);
pdf.SaveAs("Report.pdf");
Dim renderer = New ChromePdfRenderer()
Dim pdf = renderer.RenderHtmlAsPdf(htmlContent)
pdf.SaveAs("Report.pdf")
$vbLabelText   $csharpLabel

Newtonsoft Jsonpath(它是如何为开发人员工作的):图1

用例2:JSON到PDF表单

在此用例中,我们将读取JSON数据以填写PDF文档中的表单字段。 对于此示例,让我们考虑我们有以下JSON数据:

{
    "FirstName": "John",
    "LastName": "Smith",
    "PhoneNumber": "+19159969739",
    "Email": "John@email.com",
    "City": "Chicago"
}

此JSON代表一个人的个人信息。

首先,我们使用Newtonsoft.Json从文件中读取JSON数据并将其解析为字典:

string jsonString = File.ReadAllText("data.json");
var person = JsonConvert.DeserializeObject<Dictionary<string, string>>(jsonString);
string jsonString = File.ReadAllText("data.json");
var person = JsonConvert.DeserializeObject<Dictionary<string, string>>(jsonString);
Dim jsonString As String = File.ReadAllText("data.json")
Dim person = JsonConvert.DeserializeObject(Of Dictionary(Of String, String))(jsonString)
$vbLabelText   $csharpLabel

这个软件会创建一个名为person的字典,其键为“FirstName”,"LastName", "PhoneNumber", "Email",和"City"及其对应的值。

接下来,我们使用IronPdf打开PDF文档并获取表单:

var doc = PdfDocument.FromFile("myPdfForm.pdf");
var form = doc.Form;
var doc = PdfDocument.FromFile("myPdfForm.pdf");
var form = doc.Form;
Dim doc = PdfDocument.FromFile("myPdfForm.pdf")
Dim form = doc.Form
$vbLabelText   $csharpLabel

我们现在可以使用person字典来填写PDF文档中的表单字段:

form.Fields[0].Value = person["FirstName"];
form.Fields[1].Value = person["LastName"];
form.Fields[2].Value = person["PhoneNumber"];
form.Fields[3].Value = person["Email"];
form.Fields[4].Value = person["City"];
form.Fields[0].Value = person["FirstName"];
form.Fields[1].Value = person["LastName"];
form.Fields[2].Value = person["PhoneNumber"];
form.Fields[3].Value = person["Email"];
form.Fields[4].Value = person["City"];
form.Fields(0).Value = person("FirstName")
form.Fields(1).Value = person("LastName")
form.Fields(2).Value = person("PhoneNumber")
form.Fields(3).Value = person("Email")
form.Fields(4).Value = person("City")
$vbLabelText   $csharpLabel

每个表单字段都与person字典中的一个键关联。

最后,我们保存填好的PDF表单:

doc.SaveAs("myPdfForm_filled.pdf");
doc.SaveAs("myPdfForm_filled.pdf");
doc.SaveAs("myPdfForm_filled.pdf")
$vbLabelText   $csharpLabel

这种方法将创建一个新的PDF文档,并用JSON文件中的数据填满表单字段。

这展示了如何有效地使用Newtonsoft.Json解析JSON数据,并使用IronPDF来操作PDF文档。

Newtonsoft Jsonpath(它是如何为开发人员工作的):图2

用例3:将PDF元数据转换为JSON

首先,使用IronPDF从PDF中提取元数据:

var pdf = IronPdf.PdfDocument.FromFile("document.pdf");
var metadata = pdf.MetaData;
var pdf = IronPdf.PdfDocument.FromFile("document.pdf");
var metadata = pdf.MetaData;
Dim pdf = IronPdf.PdfDocument.FromFile("document.pdf")
Dim metadata = pdf.MetaData
$vbLabelText   $csharpLabel

然后,使用Newtonsoft.Json将此数据序列化为一个JSON字符串:

string jsonString = JsonConvert.SerializeObject(metadata, Formatting.Indented);
File.WriteAllText("metadata.json", jsonString);
string jsonString = JsonConvert.SerializeObject(metadata, Formatting.Indented);
File.WriteAllText("metadata.json", jsonString);
Dim jsonString As String = JsonConvert.SerializeObject(metadata, Formatting.Indented)
File.WriteAllText("metadata.json", jsonString)
$vbLabelText   $csharpLabel

在此代码中,metadata对象包含AuthorTitleCreateDate等属性。这些被序列化为一个JSON字符串并写入名为"metadata.json"的文件。

Newtonsoft Jsonpath(它是如何为开发人员工作的):图3

结合使用Newtonsoft.Json和IronPDF,您可以在PDF文件和JSON之间转换数据,满足各种使用案例。

结论

最后,Newtonsoft.Json和IronPDF一起为在.NET中处理JSON数据和生成PDF文件提供了强大而灵活的解决方案。 通过使用Newtonsoft.Json将JSON数据解析为.NET对象或字典,我们可以操作这些数据,并在各种上下文中使用它们,例如填写PDF表单或从模板生成动态PDF报告。 IronPDF使创建和管理PDF的过程变得简单高效。

本文介绍了这些库,强调了一些它们的核心功能。 然而,这两个库还有更多的功能可供探索。 我们强烈建议查看它们的广泛文档,以深入了解其功能和能力。

如果您有兴趣尝试IronPDF,他们提供IronPDF的免费试用版,以便您可以探索其功能,并评估它是否满足您的需求,然后再进行购买。 一旦您决定继续使用IronPDF,许可从IronPDF许可选项开始,其中包括对我们讨论的所有功能的持续访问以及支持和更新。 这确保您拥有工具和帮助,以有效地在您的.NET项目中生成、管理和操作PDF文件。

常见问题解答

如何安装Newtonsoft.Json以处理.NET中的JSON?

您可以使用NuGet包管理器在.NET项目中安装Newtonsoft.Json库。在包管理器控制台中执行Install-Package Newtonsoft.Json命令。安装后,用using Newtonsoft.Json;将其包含在您的项目中。

JsonConvert.DeserializeObject()的用途是什么?

JsonConvert.DeserializeObject()方法用于将JSON数据解析为.NET对象。它将JSON字符串转换为T类型的对象,使您可以在C#应用程序中处理JSON数据。

如何使用LINQ操作JSON数据?

LINQ to JSON是Newtonsoft.Json提供的一个功能,使您能够使用LINQ语法查询和操作JSON对象。这对于在.NET应用程序中高效过滤或搜索JSON数据非常有用。

如何从JSON数据生成PDF报告?

要从JSON数据生成PDF报告,首先使用Newtonsoft.Json将JSON转换为.NET对象。然后,使用这些数据创建HTML模板。使用IronPDF的ChromePdfRenderer将HTML模板转换为PDF文档。

我可以使用JSON数据填写PDF表单吗?

是的,您可以通过使用Newtonsoft.Json将JSON解析为字典,然后使用IronPDF将数据填充到PDF表单字段中,在填充完成后保存PDF文档。

我如何将PDF元数据转换为JSON?

使用IronPDF提取PDF中的元数据,并使用Newtonsoft.Json将其转换为JSON字符串。此过程使您能够轻松存储和操纵PDF元数据为JSON格式。

将Newtonsoft.Json和IronPDF一起使用有什么优势?

在.NET应用程序中使用Newtonsoft.Json和IronPDF提供了一种无缝的方法来处理JSON数据并生成或操纵PDF文件,便于进行动态报告生成、表单填写和数据交换等任务。

如何在.NET中读写JSON文件?

要读取JSON文件,使用File.ReadAllText加载JSON字符串,然后使用JsonConvert.DeserializeObject解析它。要写入JSON,请使用JsonConvert.SerializeObject序列化一个对象并使用File.WriteAllText保存它。

Curtis Chau
技术作家

Curtis Chau 拥有卡尔顿大学的计算机科学学士学位,专注于前端开发,精通 Node.js、TypeScript、JavaScript 和 React。他热衷于打造直观且美观的用户界面,喜欢使用现代框架并创建结构良好、视觉吸引力强的手册。

除了开发之外,Curtis 对物联网 (IoT) 有浓厚的兴趣,探索将硬件和软件集成的新方法。在空闲时间,他喜欢玩游戏和构建 Discord 机器人,将他对技术的热爱与创造力相结合。