JSONPath: различия между версиями

Материал из Planfix
Перейти к: навигация, поиск
Нет описания правки
Нет описания правки
Строка 26: Строка 26:
<p>"lastName": "Иванов",</p>
<p>"lastName": "Иванов",</p>
<p>"address": {</p>
<p>"address": {</p>
       <p style="padding:10px;">"streetAddress": "Московское ш., 101, кв.101",</p>
       <p style="padding:20px;">"streetAddress": "Московское ш., 101, кв.101",</p>
       <p>&nbsp;"city": "Ленинград",</p>
       <p style="padding:20px;">"city": "Ленинград",</p>
       <p>&nbsp;"postalCode": 101101</p>
       <p style="padding:20px;">"postalCode": 101101</p>
  },
  <p> },</p>
   "phoneNumbers": [
   <p>"phoneNumbers": [</p>
       "812 123-1234",
       <p>"812 123-1234",</p>
       "916 123-4567"
       <p>"916 123-4567"</p>
   ]
   <p>]</p>
}
<p>}</p>
</div>
</div>



Версия от 14:19, 12 октября 2020

Приходящие в ПланФикс письма по E-mail можно разбирать, используя JSON. JavaScript Object Notation — это формат для хранения и обмена информацией, доступной для чтения человеком. Есть два основных элемента объекта JSON: ключи и значения.

Пример:

{"city":"New York", "country":"United States"}
  • ключи — city и country;
  • значения — New York и United States.

ПланФикс умеет разбирать письма в таком формате и добавлять нужные данные в инфоблоки. Для этого используется библиотека JsonPath.


Пример

  • Передаём в ПланФикс E-mail с текстом в формате JSON:

{

"firstName": "Иван",

"lastName": "Иванов",

"address": {

"streetAddress": "Московское ш., 101, кв.101",

"city": "Ленинград",

"postalCode": 101101

},

"phoneNumbers": [

"812 123-1234",

"916 123-4567"

]

}

  • Из JSON нам необходимы следующие данные:
{
  "firstName": "Иван",
  "lastName": "Иванов",
  "address": {
      "streetAddress": "Московское ш., 101, кв.101",
      "city": "Ленинград",
      "postalCode": 101101
  },
  "phoneNumbers": [
      "812 123-1234",
      "916 123-4567"
  ]
}


  • Настраиваем такое правило для разбора почты:

MlwbbU.png