پرس و جوی JSON با JMESPath#
JMESPath یک زبان پرس و جو برای JSON است که میتوانید از آن برای استخراج و تبدیل عناصر از یک سند JSON استفاده کنید. برای جزئیات کامل نحوه استفاده از JMESPath، به مستندات JMESPath مراجعه کنید.
متد jmespath()
#
n98n یک متد سفارشی، jmespath()
را ارائه میدهد. از این متد برای انجام جستجو روی یک شیء JSON با استفاده از زبان پرس و جوی JMESPath استفاده کنید.
سینتکس پایه به این صورت است:
1 |
|
1 |
|
برای کمک به درک کاری که متد انجام میدهد، اینجا معادل JavaScript طولانیتر آمده است:
1 2 |
|
عبارات باید تک خطی باشند
مثال کد طولانیتر در عبارات کار نمیکند، زیرا آنها باید تک خطی باشند.
object
یک شیء JSON است، مانند خروجی یک نود قبلی. searchString
یک عبارت نوشته شده به زبان پرس و جوی JMESPath است. مشخصات JMESPath لیستی از عبارات پشتیبانی شده را ارائه میدهد، در حالی که آموزش و مثالهای آن مثالهای تعاملی را ارائه میدهند.
ترتیب پارامتر جستجو
مثالها در مشخصات JMESPath از الگوی search(searchString, object)
پیروی میکنند. کتابخانه JavaScript JMESPath، که n98n از آن استفاده میکند، از search(object, searchString)
پشتیبانی میکند. این بدان معناست که هنگام استفاده از مثالهای مستندات JMESPath، ممکن است نیاز به تغییر ترتیب پارامترهای تابع جستجو داشته باشید.
وظایف رایج#
این بخش مثالهایی برای برخی عملیات رایج ارائه میدهد. مثالهای بیشتر و راهنماییهای دقیق در مستندات خود JMESPath موجود است.
هنگام امتحان این مثالها، باید حالت نود کد را روی اجرای یکبار برای هر مورد تنظیم کنید.
اعمال یک عبارت JMESPath به مجموعهای از عناصر با پیشبینیها#
از مستندات پیشبینیهای JMESPath:
پیشبینیها یکی از ویژگیهای کلیدی JMESPath هستند. از آن برای اعمال یک عبارت به مجموعهای از عناصر استفاده کنید. JMESPath از پنج نوع پیشبینی پشتیبانی میکند:
- پیشبینیهای لیست
- پیشبینیهای برش
- پیشبینیهای شیء
- پیشبینیهای مسطحسازی
- پیشبینیهای فیلتر
مثال زیر استفاده پایه از پیشبینیهای لیست، برش و شیء را نشان میدهد. برای توضیحات دقیق هر نوع پیشبینی و مثالهای بیشتر، به مستندات پیشبینیهای JMESPath مراجعه کنید.
با توجه به این JSON از یک نود وبهوک:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
|
دریافت یک لیست از تمام نامهای کوچک افراد:
1 2 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
دریافت یک برش از نامهای کوچک:
1 2 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
دریافت لیستی از سن سگها با استفاده از پیشبینیهای شیء:
1 2 |
|
1 2 3 4 5 6 7 8 9 10 11 12 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
انتخاب چندین عنصر و ایجاد یک لیست یا شیء جدید#
از چند انتخابی برای انتخاب عناصر از یک شیء JSON و ترکیب آنها در یک لیست یا شیء جدید استفاده کنید.
با توجه به این JSON از یک نود وبهوک:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
|
از لیست چند انتخابی برای دریافت نامهای کوچک و خانوادگی و ایجاد لیستهای جدید حاوی هر دو نام استفاده کنید:
1 2 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
|
یک جایگزین برای توابع فلش در عبارات#
به عنوان مثال، با برگرداندن کد زیر از نود کد، برخی دادههای ورودی را تولید کنید:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 |
|
میتوانید جستجویی مانند "موردی با نام Lenovo را پیدا کنید و شناسه دسته آن را به من بگویید" انجام دهید.
1 |
|