Skip to main content

jsonfixer: fix invalid json: broken-json / truncated-json.

Project description

Usage

In [1]: from half_json.core import JSONFixer

In [2]: f = JSONFixer()

In [3]: f.fix('[{')
Out[3]: FixResult(success=True, line='[{}]', origin=False)

In [4]: f.fix('{"a')
Out[4]: FixResult(success=True, line='{"a":null}', origin=False)

In [5]: f.fix('{"a":}')
Out[5]: FixResult(success=True, line='{"a":null}', origin=False)

目标

fix invalid/broken/truncated json

修复原理

  1. JSONDecoderError
  2. line context

HitRatio

根据 checks 里面的工具来衡量修改效果

ABC : autogen --> broken --> check TSR : run test.sh show.sh ratio.sh

FixRatio

仅判断 result.success == True

./runratio.sh fix
1.  0.4269, 0.4287, 0.4303   # 实现完 12 条规则
2.  0.5037, 0.5084, 0.5077   # string 的 " 补充在末尾
3.  0.5259, 0.5224, 0.5187   # Array 需要 pos - 2
4.  0.5433, 0.5311, 0.5381   # Array 细化一下 [, 的情况
5.  0.7192, 0.7216, 0.7265   # 大改进, FIX 之前的 Bug( parser 被冲掉了)
6.  0.7732, 0.7686, 0.7701   # case: {"a":1 --> 补充 }
7.  0.60  , 0.58             # 去掉了空行
8.  0.6971, 0.6969, 0.6984   # 增加处理 StopIteration
9.  0.7428, 0.7383, 0.7427   # 增加处理 half parse
10. 0.7617, 0.7631, 0.7558   # 细化处理 half parse
11. 0.7608, 0.7612, 0.7650   # 添加从左处理
12. 0.9817, 0.9827, 0.9819   # 增加对字符串的处理
13. 0.8314, 0.8302, 0.8312   # 去掉对字符串的额外处理
14. 0.95X                    # 已不可参考

Real HitRatio

判断 result.success == True

并且解析后的 json 大体和原来一致(equal && dictdiffer)

./runratio.sh hit
1. 0.5610, 0.5563, 0.5529   # origin
2. 0.5593, 0.5532, 0.5587   # fix :} --> :null}

TODO

目前的缺点 && 发现

  1. 数字的支持比较弱 --> -02 / 0. / .0

  2. 还不支持分支回溯 --> [{]

  3. 突然想到, 应该反思一下, 这个是一个fixer, 而不是一个将任何字符串都转为 json 的东西 应该明确 JSONFixer 的能力范围, 对 runratio.sh 也应该比较前后两个的 json 相似程度。 (听起来像无能者的辩白?)

  4. 也需要吧 parser 也做成 stack 这样可以解决 ["a] --> ["a"] 这样的 case

  5. 考虑分支回溯的方式来试探

  6. 解析缺失的 JSON 常量

BadCase

  1. 1- --> {"1-": null}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jsonfixer-0.2.0a0.tar.gz (12.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

jsonfixer-0.2.0a0-py3-none-any.whl (7.7 kB view details)

Uploaded Python 3

File details

Details for the file jsonfixer-0.2.0a0.tar.gz.

File metadata

  • Download URL: jsonfixer-0.2.0a0.tar.gz
  • Upload date:
  • Size: 12.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: pdm/2.8.0 CPython/3.10.6

File hashes

Hashes for jsonfixer-0.2.0a0.tar.gz
Algorithm Hash digest
SHA256 5a35b36e266cd2c389a74aced1992b9d4e18ccedeeeef1e87972178f3ee7a120
MD5 a3b362cbeb3a367d343341851065c747
BLAKE2b-256 fa1b177a5daf38081c7e65f747d3afad827dd457d5c752b9062911160a6dee86

See more details on using hashes here.

File details

Details for the file jsonfixer-0.2.0a0-py3-none-any.whl.

File metadata

  • Download URL: jsonfixer-0.2.0a0-py3-none-any.whl
  • Upload date:
  • Size: 7.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: pdm/2.8.0 CPython/3.10.6

File hashes

Hashes for jsonfixer-0.2.0a0-py3-none-any.whl
Algorithm Hash digest
SHA256 c4dff0e0397b7dafe15c77adfd62f4136b9b19e74061a3f937b3cf6731478c66
MD5 e06df85e9bdd2390dda7fa5cd8985177
BLAKE2b-256 edbe4aa711012e2abf6b5248ab8216ebf639fd271cae1c96ab7370ac1eb5a48f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page