Skip to main content
Solved

JSON support using JSONTemplater


jorge_rosales
Contributor
Forum|alt.badge.img+8

I am trying to generate a JSON file that includes elements like this one:

But I have problems with the "positions" property. I can´t reproduce it. I can get and array ([] instead of {}) and each element like "9": [220000, 3230000] with non desired {} at the begining and the end.

I attach the full project () with the target.json that I need.

Thanks in advance.

Best answer by juanchuchow

Hi,

Try changing the value for the "positions" key in la ISLA subtemplate to this:

-----------------------

"positions": {| fme:process-features("POSITIONS", "id_isla", fme:get-attribute("id")) |}

-----------------------

Notice "|" in wrapping "{|" and "|}". "{| |}" is a merge constructor, used to merge several objects.

I ran your workspace with the "{| |}" change, instead of an array of objects you'll get a single merge object.

Hope this helps.

Juan

View original
Did this help you find an answer to your question?

6 replies

geosander
Forum|alt.badge.img+7
  • August 29, 2017

Ah yes... it's a royal pain to insert key-value pairs from features into an object. Arrays/lists are easy though... And if you omit the {} in your POSITIONS sub-template, the JSONTemplater throws an error - I wish it would allow for text in the JSONTemplater window without enclosing {} as long as the whole resulting document proves to be valid JSON!

 

I have been struggling with this before and ended up creating the objects with a PythonCaller and the JSON library...


juanchuchow
Safer
Forum|alt.badge.img+1
  • Safer
  • Best Answer
  • August 29, 2017

Hi,

Try changing the value for the "positions" key in la ISLA subtemplate to this:

-----------------------

"positions": {| fme:process-features("POSITIONS", "id_isla", fme:get-attribute("id")) |}

-----------------------

Notice "|" in wrapping "{|" and "|}". "{| |}" is a merge constructor, used to merge several objects.

I ran your workspace with the "{| |}" change, instead of an array of objects you'll get a single merge object.

Hope this helps.

Juan


geosander
Forum|alt.badge.img+7
  • August 29, 2017
juanchuchow wrote:

Hi,

Try changing the value for the "positions" key in la ISLA subtemplate to this:

-----------------------

"positions": {| fme:process-features("POSITIONS", "id_isla", fme:get-attribute("id")) |}

-----------------------

Notice "|" in wrapping "{|" and "|}". "{| |}" is a merge constructor, used to merge several objects.

I ran your workspace with the "{| |}" change, instead of an array of objects you'll get a single merge object.

Hope this helps.

Juan

Wow, that is a nice trick @juanchuchow1323! Never knew that the | (pipe) thing works like that in the JSONTemplater, so I'm glad I learned something new today! :) Wish I knew about this sooner... would have saved me a lot of work...

 

 

@j4 or @TiaAtSafe: please mark Juan's reply as the correct answer, so other people can find this too!

danilo_fme
Evangelist
Forum|alt.badge.img+41
  • Evangelist
  • August 29, 2017
juanchuchow wrote:

Hi,

Try changing the value for the "positions" key in la ISLA subtemplate to this:

-----------------------

"positions": {| fme:process-features("POSITIONS", "id_isla", fme:get-attribute("id")) |}

-----------------------

Notice "|" in wrapping "{|" and "|}". "{| |}" is a merge constructor, used to merge several objects.

I ran your workspace with the "{| |}" change, instead of an array of objects you'll get a single merge object.

Hope this helps.

Juan

Great @juanchuchow1323

 


takashi
Contributor
Forum|alt.badge.img+21
  • Contributor
  • August 30, 2017
juanchuchow wrote:

Hi,

Try changing the value for the "positions" key in la ISLA subtemplate to this:

-----------------------

"positions": {| fme:process-features("POSITIONS", "id_isla", fme:get-attribute("id")) |}

-----------------------

Notice "|" in wrapping "{|" and "|}". "{| |}" is a merge constructor, used to merge several objects.

I ran your workspace with the "{| |}" change, instead of an array of objects you'll get a single merge object.

Hope this helps.

Juan

@juanchuchow1323, thanks for sharing the tip.

 

There are only few resources about JSONiq on the Web. I finally found this one.

 

JSONiq Extension to XQuery 1.0 > 4.2. Object Constructors (Example 4.3. Dynamically building an object)

 


jorge_rosales
Contributor
Forum|alt.badge.img+8
  • Author
  • Contributor
  • August 30, 2017
juanchuchow wrote:

Hi,

Try changing the value for the "positions" key in la ISLA subtemplate to this:

-----------------------

"positions": {| fme:process-features("POSITIONS", "id_isla", fme:get-attribute("id")) |}

-----------------------

Notice "|" in wrapping "{|" and "|}". "{| |}" is a merge constructor, used to merge several objects.

I ran your workspace with the "{| |}" change, instead of an array of objects you'll get a single merge object.

Hope this helps.

Juan

It works perfectly! @juanchuchow1323 thanks a lot for the tip.

 

 


Cookie policy

We use cookies to enhance and personalize your experience. If you accept you agree to our full cookie policy. Learn more about our cookies.

 
Cookie settings