4.16667

4.2 | 6 ratings Rate this file 87 Downloads (last 30 days) File Size: 2.4 KB File ID: #20565

JSON Parser

by Joel Feenstra

 

03 Jul 2008 (Updated 18 Jun 2009)

Parses JSON strings into structures and cells

| Watch this File

File Information
Description

This function parses JSON strings. It converts JSON arrays into cell arrays and JSON objects into structures.

This can be used with webervices that return JSON data such as the API provided by Google®.

An example of use is:
  google_search = 'http://ajax.googleapis.com/ajax/services/search/web?v=1.0&q;=matlab';
  matlab_results = parse_json(urlread(google_search));
  disp(matlab_results{1}.responseData.results{1}.titleNoFormatting)
  disp(matlab_results{1}.responseData.results{1}.visibleUrl)

Acknowledgements
This submission has inspired the following:
(another) JSON Parser
MATLAB release MATLAB 7.5 (R2007b)
Tags for This File  
Everyone's Tags
data export, strings, webservice
Tags I've Applied
Add New Tags Please login to tag files.
Comments and Ratings (13)
08 Oct 2012 John Reinert Nash

Very useful tool, works as described. Thank you for simplifying parsing web API returned data.

15 Jan 2012 Qianqian Fang

FYI, an optimized JSON parser, JSONlab, based on this work is available at

http://www.mathworks.com/matlabcentral/fileexchange/33381

It is 10x to 100x faster. A JSON encoder is also provided in JSONlab.

22 Nov 2011 Boyang Gao

This version cannot deal with JSON file with empty elements. Try http://www.mathworks.com/matlabcentral/fileexchange/23393 instead(also faster).

10 Jan 2011 Benjamin Ting

This code does not appear to work if the first { is preceeded by white space (either a space or carriage return).

03 Dec 2010 Dan Massie

Works well, despite being a bit slow. Maybe it could be sped up with careful application of "regular expressions." Also, when you use the script, make sure the JSON string is a row vector of chars. Error may occur if string is a column vector of chars.

08 May 2010 Ashish Uthama  
22 Feb 2010 Han Oostdijk

Thanks Joel,

just what I needed and it works fine.

23 Mar 2009 Patrick Boert

Thanks Joel, I thought maybe there would be an easy workaround you could point me to. But the new file solves the issue, it is faster by some magnitude. In any case, thanks for your work.

23 Mar 2009 Joel Feenstra

I know that the code is slow, and I made no attempt to make the code fast, just correct. François's version does seem to be faster, so if you need speed (and have a lot of strings), use his.

23 Mar 2009 François Glineur

An alternative parser with faster handling of strings is available at http://www.mathworks.com/matlabcentral/fileexchange/23393
(another JSON Parser). For example, running the example above

companies=parse_json(urlread('http://api.crunchbase.com/v/1/companies.js'));

with it now takes less than 30 seconds.

16 Mar 2009 Patrick Boert

Hallo Joel,

thanks for the work!

I'm trying to query the Chruchbase API and it seems to work fine. However, it takes ages for some queries to get parsed, e.g. I quit

companies=parse_json(urlread('http://api.crunchbase.com/v/1/companies.js'));

after 1 hour. The profiler says that

json(1) = []; in parse_json>parse_string
json(1) = []; in parse_json>parse_object

make up about 90 % of the computational cost. Is there some easy way around this?

Best,
Patrick

08 Dec 2008 Joel Feenstra

The Google API limits it to 4 results. You can use the "cursor" information to fetch more results: matlab_results{1}.responseData.cursor

28 Nov 2008 port tracker

Good work!
BTW - Any reason why it only return 4 value object from google? Is it because of the ajax api?

Thanks,

port

Please login to add a comment or rating.
Updates
18 Jun 2009

Changed the description to properly reference Google®.

Tag Activity for this File
Tag Applied By Date/Time
data import Joel Feenstra 22 Oct 2008 10:08:23
data export Joel Feenstra 22 Oct 2008 10:08:23
json Joel Feenstra 22 Oct 2008 10:08:23
webservice Joel Feenstra 22 Oct 2008 10:08:23
strings Joel Feenstra 22 Oct 2008 10:08:23
parses Joel Feenstra 22 Oct 2008 10:08:23
cell arrays Joel Feenstra 22 Oct 2008 10:08:23
arrays Joel Feenstra 22 Oct 2008 10:08:23
converts Joel Feenstra 22 Oct 2008 10:08:23
json Zigo 05 Sep 2011 10:11:58
data import Zigo 05 Sep 2011 10:12:01
cell arrays Rick Staals 14 Oct 2012 14:27:56

Contact us at [email protected]

 

Follow Lee on X/Twitter - Father, Husband, Serial builder creating AI, crypto, games & web tools. We are friends :) AI Will Come To Life!

Check out: eBank.nz (Art Generator) | Netwrck.com (AI Tools) | Text-Generator.io (AI API) | BitBank.nz (Crypto AI) | ReadingTime (Kids Reading) | RewordGame | BigMultiplayerChess | WebFiddle | How.nz | Helix AI Assistant