揰掵佲 发表于 2017-6-11 00:44:29

JimStone(谢栋) - JSON模块:STJson2.2(开源+示例) - 纯算法

JimStone(谢栋) - JSON模块:STJson2.2(开源+示例) - 纯算法2.2 加入二次寻址机制

[*]当存在 路径 和 句柄 参数时,如果 句柄 大于 0,而且路径也存在时,则基于 句柄 执行二次寻址

下载:下载次数:188


例如:
json内容:
复制代码

[*]{
[*]"a": [
[*]{
[*]   "b": 101
[*]},
[*]{
[*]   "b": 102
[*]},
[*]{
[*]   "b": 103
[*]}
[*]]
[*]}

代码:
复制代码

[*].版本 2
[*]
[*].局部变量 句柄, 整数型
[*].局部变量 快速JSON, 快速JSON解析类
[*]
[*]快速JSON.解析 (json内容)
[*]句柄 = 快速JSON.取数组句柄 (“a”, , 2)
[*]输出调试文本 (快速JSON.取文本 (“b”, 句柄))


输出文本:
复制代码

[*]* 102


2.1 修复了逻辑型和NULL类型取值和取文本出错的问题

[*]修复了上个版本取逻辑和null文本出错和取值内容不正确的问题(忘记标记数据位置了,惭愧)


2.0版本特性

[*]加入了全新的快速解析对象,解析效率提高了5到10倍。
[*]全新的解析算法全面兼容JSON标准。完全支持科学计数法、Unicode、JSON标准转义符、单行多行注释、多字节文本。
[*]读取支持路径式访问并且效率非常高。例如:a.b、a.b、.b、['我'].b。需要注意的是,数组访问索引是从1开始的。
[*]快速解析对象加入中文命名代理类。
[*]修复上个版本双精度小数的问题。
[*]原来的对象解析部分挂接了新的解析对象,效率更高,兼容性更好。
已经通过大量的测试,修复了上个版本多种特殊情况下可能解析失败的问题。
   



http://bbs.eyuyan.com/attachment/thumb/Mon_1706/124_4422_133f88ae9f854c9.png?70
   
快速解析对象使用方法

类:快速JSON解析类 / STFastJson


取句柄() / get_handle(): 返回 节点句柄。失败返回 0。通过路径获取节点的原始句柄信息。

引用
使用句柄获取数据的效率比通过路径获取数据效率更高。句柄 实际指向数据信息存储的位置。根节点句柄必然为 1。


----------------------------------------------------------------------------
大部分参数都包含 路径(path) 和 句柄(handle) 两个参数。
如果句柄大于0则基于句柄执行路径查询。
路径访问类似JS中的访问方式:

数组访问:

[*]数组使用“[数组索引]”的方式访问,索引值从1开始。例如:a.name、a.b.name
[*]根节点为数组则直接使用数组规则访问。例如:.name、.a.b、.a.b
对象访问:

[*]对象直接使用“.节点名称”下级节点名称访问。例如:a.b、book.cover.url
[*]根节点为对象则直接使用下级节点名称访问。例如:user.name、object.property
[*]如果对象主键名称不为数字、字母或下划线,则使用“['主键']”(支持单引号或双引号包裹名称)的方式访问。例如:user['信息'].address、bbs.article['id']、['用户'].['名称']、['用户']['名称']

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

解析() / parse() : 解析JSON文本。

[*]参数 [是否保留顺序]:指定是否保留对象原始节点顺序。如果保留原始顺序,则 取对象所有主键() 方法返回的主键将使用原始顺序。如果为 真 则解析效率会有细微的下降。如果对对象下级节点的顺序要求不高的情况下,建议设置本参数为 假。
[*]参数 [错误原因]:在解析失败时,会返回详细的错误原因,错误原因包含行号和错误所在行中的位置。
[*]参数 [是否Unicode转GBK] : 是否将Unicode“\u”符号转换为GBK。默认:真

取对象句柄() /get_object_handle(): 通过对象主键返回对象的下级节点句柄。

取数组句柄() / get_array_handle():通过数组索引返回数组的下级节点句柄。

取类型() / get_type() : 获取节点的类型。返回类型对应“#快速JSON类型_” / “#JFTYPE_” 开头的常量。注意此处的英文常量比构造和原JSON类中多了个 F,为 #JFTYPE_。

取数组成员数() / get_array_count() : 返回数组成员数量。非数组时返回0

取对象所有主键() / get_object_keys() : 获取对象所有下级属性节点的主键。返回主键数量,主键内容存到“主键数组”参数中

取文本() / get_string() : 返回节点文本内容。数组返回“”,对象返回“Object”,其它对象则返回原始文本内容

取整数() / get_long() : 返回节点内容为长整数。双精度小数/长整数/文本都将被自动转换,其它返回0

取小数() / get_double() : 返回节点内容为双精度小数。双精度小数/长整数/文本都将被自动转换,其它返回0

取逻辑值() / get_bool() : 返回节点内容为逻辑型。不存在或非逻辑型返回 假

是否为空() / is_null() : 判断是否为空。不存在的节点也返回 真,存在且非null型返回 假

是否存在() / exists() : 判断节点是否存在

wan942182718 发表于 2017-9-28 21:41:21

解析是能解析

wan942182718 发表于 2017-9-28 21:41:55

就是 不是顺序解析

xiaokai 发表于 2018-8-7 11:40:59

页: [1]
查看完整版本: JimStone(谢栋) - JSON模块:STJson2.2(开源+示例) - 纯算法