dongqie2010 2015-05-11 14:17
浏览 113

php加载大json文件一次

I created a local web application to display and interact with data that I got an a big Json file (around 250 Mo). I have several function in order to display differently the data but currently each one starts by reading and parsing the Json file :

$string = file_get_contents("myFile.json");
$json_a = json_decode($string, true);

The thing is that it is quite slow (about 4 seconds) because the file is big... So I would like to parse the Json file once and for all and store the parsed data in memory so that each function could use it :

session_start();
$string = file_get_contents("myFile.json");
$_SESSION['json_a'] = json_decode($string, true);

and then use $_SESSION['json_a'] in my functions. But I got an error when the function access to this $_SESSION['json_a'] variable :

Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 195799278 bytes)

I assume it is because the file is too big.. but why does it crash when the variable is used and not when it is built ? And why can I do it with my first solution (parsing each time) if it is too big for the memory ?

And finally my real question : how can I optimise that ? (I know sql database would be much better but I happen to have json data)

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 有了解d3和topogram.js库的吗?有偿请教
    • ¥100 任意维数的K均值聚类
    • ¥15 stamps做sbas-insar,时序沉降图怎么画
    • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
    • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
    • ¥15 关于#Java#的问题,如何解决?
    • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
    • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
    • ¥15 cmd cl 0x000007b
    • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line