成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

竟然還能這樣高效地操作 JSON 對象!

開發 前端
當處理大型或復雜的 JSON 數據結構時,定位特定值可能會變得非常麻煩。使用 JSON Pointer 可以讓你以一種簡單而準確的方式指定所需值的位置,而不需要編寫復雜的代碼來遍歷整個 JSON 結構。

什么是 JSON Pointer

JSON Pointer[1] 是一種用于定位 JSON(JavaScript Object Notation)文檔中特定值的簡單而強大的方法。它通過使用斜杠 / 分隔符來指示 JSON 對象的層級結構,以確切地標識所需值的位置。

為什么使用 JSON Pointer

當處理大型或復雜的 JSON 數據結構時,定位特定值可能會變得非常麻煩。使用 JSON Pointer 可以讓你以一種簡單而準確的方式指定所需值的位置,而不需要編寫復雜的代碼來遍歷整個 JSON 結構。這極大地簡化了 JSON 數據的定位和操作過程。

此外,JSON Pointer 還具有以下優點:

  • 通用性:JSON Pointer 是一種通用的標準,因此可以在各種編程語言和平臺上使用。這種通用性使得 JSON Pointer 成為跨平臺開發和數據交換的理想選擇。
  • 效率:由于 JSON Pointer 可以直接定位到所需值,因此它在處理大型 JSON 數據時效率很高。相比于傳統的逐層遍歷搜索方式,JSON Pointer 能夠更快速地找到目標值。
  • 簡單易懂:JSON Pointer 使用類似文件路徑的語法,因此非常直觀和易于理解。它的語法簡潔清晰,使得使用者可以輕松地理解和使用它。
  • 精確定位:JSON Pointer 允許你以非常準確的方式指定 JSON 對象中的值,而無需關心其周圍的結構。這意味著你可以專注于所需值的確切位置,而不必擔心其他內容。

如何使用 JSON Pointer

很多常見的開發語言,都實現了 JSON Pointer 規范。在 Node.js 環境,我們可以使用 jsonpointer[2] 這個庫。

首先,使用 npm 或 pnpm 來安裝 jsonpointer:

npm install jsonpointer
or 
pnpm add jsonpointer

成功安裝 jsonpointer 庫之后,我們就可以利用它提供的 API 來快速的定位和操作 JSON 對象。

1.獲取指定路徑的屬性值

JSON Pointer 使用斜杠 / 分隔符來指示 JSON 對象的層級結構,如果指定的路徑不存在,則會返回 undefined。

const jsonpointer = require("jsonpointer");
let obj = {
  foo: 1,
  bar: { baz: 2 },
  qux: [3, 4, 5],
  zoo: {
    e: [{ a: 3 }, { b: 4 }, { c: 5 }],
  },
};

jsonpointer.get(obj, "/foo"); // returns 1
jsonpointer.get(obj, "/bar/baz"); // returns 2

jsonpointer.get(obj, "/quo"); // returns undefined

2.獲取數組對象指定位置的值

若要訪問指定位置的數組元素,則需要在 / 分隔符后面添加該元素的索引。

jsonpointer.get(obj, "/qux/0"); // returns 3
jsonpointer.get(obj, "/qux/1"); // returns 4
jsonpointer.get(obj, "/qux/2"); // returns 5

如果數組元素也是對象的話,我們只需按照屬性的層級結構進行訪問路徑即可。

jsonpointer.get(obj, "/zoo/e/0/a"); // returns 3
jsonpointer.get(obj, "/zoo/e/1/b"); // returns 4
jsonpointer.get(obj, "/zoo/e/2/c"); // returns 5

除了,獲取 JSON 對象的值之外,通過使用 jsonpointer 這個庫提供的 set 方法,我們也可以設置指定路徑的值。

3.設置指定路徑的屬性值

JSON Pointer 提供了一種往數組中插入新元素的便捷語法,即在 / 路徑后添加 - 符號:

// sets obj.foo = 6;
jsonpointer.set(obj, "/foo", 6); 
// sets obj.qux = [3, 4, 5, 6]
jsonpointer.set(obj, "/qux/-", 6); 

// set zoo.e = [{"a":3},{"b":4},{"c":5},{"d":6}]
jsonpointer.set(obj, "/zoo/e/-", { d: 6 });

除了上面介紹的 set 和 get 方法之外,jsonpointer 這個庫還提供了一個 compile 方法,該方法會返回一個新的 JSON Pointer 對象,讓我們更方便地訪問 JSON 對象特定路徑的屬性。

const pointer = jsonpointer.compile("/foo");
pointer.get(obj); // returns 6
pointer.set(obj, 1); // sets obj.foo = 1

JSON Pointer 在 LangchainJS 中的應用

在 LangchainJS 的 JSONLoader[3] 中,也用到了 jsonpointer 這個庫。使用該庫的主要目的是為了能快速從 JSON 對象中,提取用戶想要的數據。

使用示例

example.json

{
  "1": {
    "body": "BD 2023 SUMMER",
    "from": "LinkedIn Job",
    "labels": ["IMPORTANT", "CATEGORY_UPDATES", "INBOX"]
  },
  "2": {
    "body": "Intern, Treasury and other roles are available",
    "from": "LinkedIn Job2",
    "labels": ["IMPORTANT"],
    "other": {
      "name": "plop",
      "surname": "bob"
    }
  }
}

JSONLoader

export declare class JSONLoader extends TextLoader {
    pointers: string[];
    constructor(filePathOrBlob: string | Blob, pointers?: string | string[]);
}

假設我們只想要提取 from 和 surname 的信息:

import { JSONLoader } from "langchain/document_loaders/fs/json";

const loader = new JSONLoader(
  "src/document_loaders/example_data/example.json",
  ["/from", "/surname"]
);

const docs = await loader.load();

通過設置 pointers 參數的值為 ["/from", "/surname"],我們就實現了快速提取 JSON 對象中想要的數據。

[
  Document {
    pageContent: 'LinkedIn Job',
    metadata: { source: './src/json/example.json', line: 1 }
  },
  Document {
    pageContent: 'LinkedIn Job2',
    metadata: { source: './src/json/example.json', line: 2 }
  },
  Document {
    pageContent: 'bob',
    metadata: { source: './src/json/example.json', line: 3 }
  }
]

參考資料

[1]JSON Pointer: https://datatracker.ietf.org/doc/html/rfc6901

[2]jsonpointer: https://www.npmjs.com/package/jsonpointer

[3]JSONLoader: https://js.langchain.com/docs/modules/data_connection/document_loaders/json

責任編輯:武曉燕 來源: 全棧修仙之路
相關推薦

2021-07-28 06:10:47

拖拽設計器 transmat

2020-11-16 13:38:31

PostMessage

2021-11-10 06:38:01

Python鏈式操作

2021-10-29 07:49:22

Spring事務管理

2021-09-05 07:55:37

前端Emoji 表情

2022-07-04 08:16:43

JSONJSON庫對象

2012-07-13 11:32:16

網絡出口

2019-02-26 14:43:50

http狀態碼前端

2024-08-02 08:38:20

Controller接口地址

2020-09-14 11:26:54

BinlogCanal數據庫

2021-03-08 07:46:53

Git開源控制系統

2024-02-04 12:21:59

AI模型

2020-09-29 06:45:49

JDK

2020-08-14 08:19:25

Shell命令行數據

2022-05-11 09:51:10

云計算公共云

2021-08-05 18:34:55

IntelliJ ID高效

2023-11-16 20:37:01

2020-12-15 08:05:40

路由器服務器網絡層

2019-01-29 10:00:59

GitHub開源搜索

2021-07-28 06:51:08

Nacos代理模式
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美日韩精品 | 三级在线观看 | 国产精品久久精品 | 黄色一级片视频 | 一级国产精品一级国产精品片 | 男女那个视频 | jlzzjlzz欧美大全 | 国产99久久精品一区二区300 | 香蕉久久a毛片 | 国产麻豆乱码精品一区二区三区 | 自拍偷拍亚洲视频 | 欧美日韩精品 | 一起操网站 | 成人av片在线观看 | 日韩av中文| 日韩精品一区中文字幕 | 国产亚洲精品一区二区三区 | 久久久久久一区 | 色播久久久 | 亚洲区一 | 欧洲国产精品视频 | 国产视频综合 | 精品一区二区三区视频在线观看 | 99久久婷婷国产亚洲终合精品 | 色视频在线播放 | 国产成人精品一区二区三区四区 | 激情久久网 | 欧美一区二区三区在线观看 | 久久99国产精一区二区三区 | 日本欧美在线观看视频 | 日韩精品成人一区二区三区视频 | 久久手机在线视频 | 亚洲国产精品久久久久婷婷老年 | 久久看精品| 福利精品在线观看 | 97免费在线观看视频 | 91中文在线观看 | 亚洲一在线 | 欧美视频成人 | 一区二区三区不卡视频 | 久久久久九九九九 |