🐍 A hyper-fast Python module for reading/writing JSON data using Rust's serde-json.

Overview

hyperjson

Build Status

A hyper-fast, safe Python module to read and write JSON data. Works as a drop-in replacement for Python's built-in json module. This is alpha software and there will be bugs, so maybe don't deploy to production just yet. 😉

⚠️ NOTE

This project is not actively maintained. orjson is likely the better alternative.

Installation

pip install hyperjson

Usage

hyperjson is meant as a drop-in replacement for Python's json module:

>>> import hyperjson
>>> hyperjson.dumps([{"key": "value"}, 81, True])
'[{"key":"value"},81,true]'
>>> hyperjson.loads("""[{"key": "value"}, 81, true]""")
[{u'key': u'value'}, 81, True]

Motivation

Parsing JSON is a solved problem; so, no need to reinvent the wheel, right?
Well, unless you care about performance and safety.

Turns out, parsing JSON correctly is a hard problem. Thanks to Rust however, we can minimize the risk of running into stack overflows or segmentation faults however.

hyperjson is a thin wrapper around Rust's serde-json and pyo3. It is compatible with Python 3 (and 2 on a best-effort basis).

For a more in-depth discussion, watch the talk about this project recorded at the Rust Cologne Meetup in August 2018.

Goals

  • Compatibility: Support the full feature-set of Python's json module.
  • Safety: No segfaults, panics, or overflows.
  • Performance: Significantly faster than json and as fast as ujson (both written in C).

Non-goals

  • Support ujson and simplejson extensions:
    Custom extensions like encode(), __json__(), or toDict() are not supported. The reason is, that they go against PEP8 (e.g. dunder methods are restricted to the standard library, camelCase is not Pythonic) and are not available in Python's json module.
  • Whitespace preservation: Whitespace in JSON strings is not preserved. Mainly because JSON is a whitespace-agnostic format and serde-json strips them out by default. In practice this should not be a problem, since your application must not depend on whitespace padding, but it's something to be aware of.

Benchmark

We are not fast yet. That said, we haven't done any big optimizations. In the long-term we might explore features of newer CPUs like multi-core and SIMD. That's one area other (C-based) JSON extensions haven't touched yet, because it might make code harder to debug and prone to race-conditions. In Rust, this is feasible due to crates like faster or rayon.

So there's a chance that the following measurements might improve soon.
If you want to help, check the instructions in the Development Environment section below.

Test machine:
MacBook Pro 15 inch, Mid 2015 (2,2 GHz Intel Core i7, 16 GB RAM) Darwin 17.6.18

Serialization benchmarks Deserialization benchmarks

Contributions welcome!

If you would like to hack on hyperjson, here's what needs to be done:

Just pick one of the open tickets. We can provide mentorship if you like. 😃

Developer guide

This project uses poetry for managing the development environment. If you don't have it installed, run

curl -sSL https://raw.githubusercontent.com/python-poetry/poetry/master/get-poetry.py | python
export PATH="$HOME/.poetry/bin:$PATH"

The project requires the nightly version of Rust.

Install it via rustup:

rustup install nightly

If you have already installed the nightly version, make sure it is up-to-date:

rustup update nightly

After that, you can compile the current version of hyperjson and execute all tests and benchmarks with the following commands:

make install
make test
make bench

🤫 Pssst!... run make help to learn more.

Drawing pretty diagrams

In order to recreate the benchmark histograms, you first need a few additional prerequisites:

On macOS, please also add the following to your ~/.matplotlib/matplotlibrc (reference):

backend: TkAgg

After that, run the following:

make plot

License

hyperjson is licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in hyperjson by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Comments
  • Error when installing via pip

    Error when installing via pip

    Both pipenv install hyperjson and pip install hyperjson produce the following error:

      Could not find a version that satisfies the requirement hyperjson (from versions: )
    No matching distribution found for hyperjson
    

    Tried this on Ubuntu 18.10 with python 3.6.7

    opened by ZapAnton 11
  • [Github Action] Test and Bench via github actions

    [Github Action] Test and Bench via github actions

    This sets up a github action to build/test/bench hyperjson across 3.5, 3.6, 3.7 x macos/ubuntu. This is my first github action, so things might not be as optimal as they could be. doesnt help with #60 atm, but deploying wheels looks pretty straightforward now that I'm comfy with actions.

    opened by packysauce 10
  • Fix remaining unit tests

    Fix remaining unit tests

    Here is a list of failing tests and their status:

    ============================ FAILURES =============================
    ________________ UltraJSONTests.testEncodeSymbols _________________
    
    self = <test_ujson.UltraJSONTests testMethod=testEncodeSymbols>
    
        def testEncodeSymbols(self):
            s = '\u273f\u2661\u273f'  # ✿♡✿
            encoded = hyperjson.dumps(s)
            encoded_json = hyperjson.dumps(s)
    >       self.assertEqual(len(encoded), len(s) * 6 + 2)  # 6 characters + quotes
    E       AssertionError: 5 != 20
    
    hyperjson/tests/test_ujson.py:229: AssertionError
    _______________ UltraJSONTests.testEncodeUnicodeBMP _______________
    
    self = <test_ujson.UltraJSONTests testMethod=testEncodeUnicodeBMP>
    
        def testEncodeUnicodeBMP(self):
            s = '\U0001f42e\U0001f42e\U0001F42D\U0001F42D'  # 🐮🐮🐭🐭
            encoded = hyperjson.dumps(s)
            encoded_json = hyperjson.dumps(s)
    
            if len(s) == 4:
    >           self.assertEqual(len(encoded), len(s) * 12 + 2)
    E           AssertionError: 6 != 50
    
    hyperjson/tests/test_ujson.py:204: AssertionError
    _____________ UltraJSONTests.test_ReadBadObjectSyntax _____________
    
    self = <test_ujson.UltraJSONTests testMethod=test_ReadBadObjectSyntax>
    
        def test_ReadBadObjectSyntax(self):
            input = '{"age", 44}'
    >       self.assertRaises(ValueError, hyperjson.loads, input)
    E       _hyperjson.JSONDecodeError: Value: "{\"age\", 44}", Error: expected `:` at line 1 column 7
    
    hyperjson/tests/test_ujson.py:820: JSONDecodeError
    _________ UltraJSONTests.test_WriteArrayOfSymbolsFromList _________
    
    self = <test_ujson.UltraJSONTests testMethod=test_WriteArrayOfSymbolsFromList>
    
        def test_WriteArrayOfSymbolsFromList(self):
            self.assertEqual("[true, false, null]",
    >                        hyperjson.dumps([True, False, None]))
    E       AssertionError: '[true, false, null]' != '[true,false,null]'
    E       - [true, false, null]
    E       ?       -      -
    E       + [true,false,null]
    
    hyperjson/tests/test_ujson.py:846: AssertionError
    ________ UltraJSONTests.test_WriteArrayOfSymbolsFromTuple _________
    
    self = <test_ujson.UltraJSONTests testMethod=test_WriteArrayOfSymbolsFromTuple>
    
        def test_WriteArrayOfSymbolsFromTuple(self):
            self.assertEqual("[true, false, null]",
    >                        hyperjson.dumps((True, False, None)))
    E       AssertionError: '[true, false, null]' != '[true,false,null]'
    E       - [true, false, null]
    E       ?       -      -
    E       + [true,false,null]
    
    hyperjson/tests/test_ujson.py:850: AssertionError
    ___________ UltraJSONTests.test_decodeArrayDepthTooBig ____________
    
    self = <test_ujson.UltraJSONTests testMethod=test_decodeArrayDepthTooBig>
    
        def test_decodeArrayDepthTooBig(self):
            input = '[' * (1024 * 1024)
    >       self.assertRaises(RecursionError, hyperjson.loads, input)
    E       _hyperjson.JSONDecodeError: Value: "[{{", Error: key must be a string at line 1 column 2
    
    hyperjson/tests/test_ujson.py:397: JSONDecodeError
    _______________________________ UltraJSONTests.test_decodeTrueBroken ________________________________
    
    self = <test_ujson.UltraJSONTests testMethod=test_decodeTrueBroken>
    
        def test_decodeTrueBroken(self):
            input = "tru"
    >       self.assertRaises(ValueError, hyperjson.loads, input)
    E       _hyperjson.JSONDecodeError: Value: "tru", Error: expected ident at line 1 column 3
    
    hyperjson/tests/test_ujson.py:413: JSONDecodeError
    _______________________ UltraJSONTests.test_decodeWithTrailingNonWhitespaces ________________________
    
    self = <test_ujson.UltraJSONTests testMethod=test_decodeWithTrailingNonWhitespaces>
    
        def test_decodeWithTrailingNonWhitespaces(self):
            input = "{}\n\t a"
    >       self.assertRaises(JSONDecodeError, hyperjson.loads, input)
    E       _hyperjson.JSONDecodeError: Value: "{}\n\t a", Error: trailing characters at line 2 column 3
    
    hyperjson/tests/test_ujson.py:790: JSONDecodeError
    __________________________________ UltraJSONTests.test_dumpToFile ___________________________________
    
    self = <test_ujson.UltraJSONTests testMethod=test_dumpToFile>
    
        def test_dumpToFile(self):
            f = six.StringIO()
            hyperjson.dump([1, 2, 3], f)
    >       self.assertEqual("[1, 2, 3]", f.getvalue())
    E       AssertionError: '[1, 2, 3]' != '[1,2,3]'
    E       - [1, 2, 3]
    E       ?    -  -
    E       + [1,2,3]
    
    hyperjson/tests/test_ujson.py:556: AssertionError
    _____________________________ UltraJSONTests.test_dumpToFileLikeObject ______________________________
    
    self = <test_ujson.UltraJSONTests testMethod=test_dumpToFileLikeObject>
    
        def test_dumpToFileLikeObject(self):
            class filelike:
                def __init__(self):
                    self.bytes = ''
    
                def write(self, bytes):
                    self.bytes += bytes
    
            f = filelike()
            hyperjson.dump([1, 2, 3], f)
    >       self.assertEqual("[1, 2, 3]", f.bytes)
    E       AssertionError: '[1, 2, 3]' != '[1,2,3]'
    E       - [1, 2, 3]
    E       ?    -  -
    E       + [1,2,3]
    
    hyperjson/tests/test_ujson.py:568: AssertionError
    _______________________ UltraJSONTests.test_encodeListLongUnsignedConversion ________________________
    
    self = <test_ujson.UltraJSONTests testMethod=test_encodeListLongUnsignedConversion>
    
        def test_encodeListLongUnsignedConversion(self):
            input = [18446744073709551615,
                     18446744073709551615, 18446744073709551615]
            output = hyperjson.dumps(input)
    
    >       self.assertEqual(input, hyperjson.loads(output))
    E       AssertionError: Lists differ: [18446744073709551615, 18446744073709551615, 18446744073709551615] != [1.8446744073709552e+19, 1.8446744073709552e+19, 1.8446744073709552e+19]
    E
    E       First differing element 0:
    E       18446744073709551615
    E       1.8446744073709552e+19
    E
    E       - [18446744073709551615, 18446744073709551615, 18446744073709551615]
    E       ?                   ^ ^^^^                ^ ^^^^                ^^^
    E
    E       + [1.8446744073709552e+19, 1.8446744073709552e+19, 1.8446744073709552e+19]
    E       ?   +               +++ ^^^ ^               +++ ^^^ ^               +++ ^
    
    hyperjson/tests/test_ujson.py:495: AssertionError
    _________________________ UltraJSONTests.test_encodeLongUnsignedConversion __________________________
    
    self = <test_ujson.UltraJSONTests testMethod=test_encodeLongUnsignedConversion>
    
        def test_encodeLongUnsignedConversion(self):
            input = 18446744073709551615
            output = hyperjson.dumps(input)
    
    >       self.assertEqual(input, hyperjson.loads(output))
    E       AssertionError: 18446744073709551615 != 1.8446744073709552e+19
    
    hyperjson/tests/test_ujson.py:509: AssertionError
    _______________________________ UltraJSONTests.test_encodeOrderedDict _______________________________
    
    self = <test_ujson.UltraJSONTests testMethod=test_encodeOrderedDict>
    
        @unittest.skipIf(sys.version_info < (2, 7), "No Ordered dict in < 2.7")
        def test_encodeOrderedDict(self):
            from collections import OrderedDict
            input = OrderedDict([(1, 1), (0, 0), (8, 8), (2, 2)])
            self.assertEqual('{"1": 1, "0": 0, "8": 8, "2": 2}',
    >                        hyperjson.dumps(input))
    E       AssertionError: '{"1": 1, "0": 0, "8": 8, "2": 2}' != '{"0":0,"1":1,"2":2,"8":8}'
    E       - {"1": 1, "0": 0, "8": 8, "2": 2}
    E       + {"0":0,"1":1,"2":2,"8":8}
    
    hyperjson/tests/test_ujson.py:369: AssertionError
    ___________________________________ UltraJSONTests.test_sortKeys ____________________________________
    
    self = <test_ujson.UltraJSONTests testMethod=test_sortKeys>
    
        def test_sortKeys(self):
            data = {"a": 1, "c": 1, "b": 1, "e": 1, "f": 1, "d": 1}
            sortedKeys = hyperjson.dumps(data, sort_keys=True)
            self.assertEqual(
    >           sortedKeys, '{"a": 1, "b": 1, "c": 1, "d": 1, "e": 1, "f": 1}')
    E       AssertionError: '{"a":1,"b":1,"c":1,"d":1,"e":1,"f":1}' != '{"a": 1, "b": 1, "c": 1, "d": 1, "e": 1, "f": 1}'
    E       - {"a":1,"b":1,"c":1,"d":1,"e":1,"f":1}
    E       + {"a": 1, "b": 1, "c": 1, "d": 1, "e": 1, "f": 1}
    E       ?      +  +    +  +    +  +    +  +    +  +    +
    
    hyperjson/tests/test_ujson.py:865: AssertionError
    ========================= 30 failed, 102 passed, 28 skipped in 9.44 seconds =========================
    
    bug help wanted good first issue 
    opened by mre 10
  • Applied several clippy suggestions

    Applied several clippy suggestions

    This PR tries to reduce the warning-noise when cargo clippy is applied.

    The most common warning was about passing arguments by value instead of passing by reference:

    warning: this argument is passed by value, but not consumed in the function body
       --> src/lib.rs:228:8
        |
    228 |     s: PyObject,
        |        ^^^^^^^^ help: consider taking a reference instead: `&PyObject`
        |
        = help: for further information visit https://rust-lang-nursery.github.io/rust-clippy/v0.0.212/index.html#needless_pass_by_value
    

    Some of the warnings I managed to resolve, but for functions annotated with #[pyfunction] the simple usage of &Option<> introduces an error:

    error[E0277]: the trait bound `pyo3::PyObject: pyo3::PyTypeInfo` is not satisfied                                                                                                             
       --> src/lib.rs:153:1                                                                                                                                                                       
        |                                                                                                                                                                                         
    153 | #[pyfunction]                                                                                                                                                                           
        | ^^^^^^^^^^^^^ the trait `pyo3::PyTypeInfo` is not implemented for `pyo3::PyObject`                                                                                                      
        |                                                                                                                                                                                         
        = note: required because of the requirements on the impl of `pyo3::PyTryFrom` for `pyo3::PyObject`                                                                                        
        = note: required because of the requirements on the impl of `pyo3::FromPyObject<'_>` for `&pyo3::PyObject`                                                                                
        = note: required by `pyo3::ObjectProtocol::extract`   
    

    The way to resolve the error could be the usage the PyObjectRef and also the usage of #[pyfn()] instead of #[pyfunction] (actually could not find #[pyfunction] in the 0.5.0 documentation - could it be deprecated?), but that would introduce the API breakage, so I left it for now.

    The result changes are somewhat chaotic, so feel free to close

    opened by ZapAnton 8
  • [bump_pyo3_version] Update to pyo3 0.8.0 and maturin

    [bump_pyo3_version] Update to pyo3 0.8.0 and maturin

    Like the title states. 0.6.0 introduced some API incompatibilities that I have fixed to the best of my abilities. I also went ahead and updated every dep involved, and fixed all incompatibilities discovered.

    I ran profiles, tests, and played around with it in the python shell, and from what I can tell works well again

    should fix #57

    opened by packysauce 7
  • Linking error with make build

    Linking error with make build

    make build and by extension cargo build, cargo test and cargo bench fail with the following error:

    error: linking with `cc` failed: exit code: 1
    ..... A lot of output ....
    undefined reference to `PyExc_TypeError'
    collect2: error: ld returned 1 exit status
    

    Perhaps the build command should be modified to match setuptools-rust one?

    E.g.

    cargo rustc --lib --manifest-path Cargo.toml --features pyo3/extension-module pyo3/python3 --release -- --crate-type cdylib
    
    opened by ZapAnton 7
  • Automate deployment to Pypi

    Automate deployment to Pypi

    We should automate the deployment process of hyperjson. Since I had some great experiences with Github actions, I would prefer to write a completely new CI pipeline with it and remove Travis from the project.

    The pipeline should...

    • run the tests
    • publish the Python package for Python 3.5, 3.6, 3.7, and optionally sdist with the help of maturin.
    • (optionally) release to crates.io

    If someone wants to tackle this, please go ahead. 😊

    help wanted good first issue mentorship hacktoberfest 
    opened by mre 5
  • Nice performance boost for handling boolean values

    Nice performance boost for handling boolean values

    We can serialize to bool directly without using extract. This gives us a nice performance boost as can be seen in the new plots. The same trick can probably be applied elsewhere. Good places to look for such improvements are the remaining extract calls and the macro handling for casts.

    opened by mre 5
  • Find and fix possible performance bottlenecks

    Find and fix possible performance bottlenecks

    Yesterday I did some profiling using the setup described here. The resulting callgrind file is attached. This can be opened with qcachegrind on Mac or kcachegrind on Linux.

    callgrind.out.35583.zip

    If you don't have any of those programs handy, I've added a screenshot for the two main bottlenecks that I can see. I'm not an expert, but it looks like we spend a lot of time allocating, converting, and dropping the BTreeMap, which will be converted to a dictionary and returned to Python in the end.

    I guess we could save a lot of time by making this part more efficient. E.g. by copying less and instead working on references. Might be mistaken, though. Help and pull requests are very welcome. 😊

    hyperjson-bench enhancement mentorship 
    opened by mre 5
  • Fixup CI

    Fixup CI

    Github deprecated the ::add_path command sometime in October which is causing the CI to fail, adding platform specific steps for modifying the PATH should fix this (at least it did in my poetry/py03 project).

    Relevant error:

    The `add-path` command is disabled. Please upgrade to using Environment Files or opt into unsecure command execution by setting the `ACTIONS_ALLOW_UNSECURE_COMMANDS` environment variable to `true`. For more information see: https://github.blog/changelog/2020-10-01-github-actions-deprecating-set-env-and-add-path-commands/ 
    
    opened by wseaton 4
  • Bump pytest from 5.2.4 to 5.3.0

    Bump pytest from 5.2.4 to 5.3.0

    Bumps pytest from 5.2.4 to 5.3.0.

    Release notes

    Sourced from pytest's releases.

    5.3.0

    pytest 5.3.0 (2019-11-19)

    Deprecations

    • #6179: The default value of junit_family option will change to xunit2 in pytest 6.0, given that this is the version supported by default in modern tools that manipulate this type of file.

      In order to smooth the transition, pytest will issue a warning in case the --junitxml option is given in the command line but junit_family is not explicitly configured in pytest.ini.

      For more information, see the docs.

    Features

    • #4488: The pytest team has created the pytest-reportlog plugin, which provides a new --report-log=FILE option that writes report logs into a file as the test session executes.

      Each line of the report log contains a self contained JSON object corresponding to a testing event, such as a collection or a test result report. The file is guaranteed to be flushed after writing each line, so systems can read and process events in real-time.

      The plugin is meant to replace the --resultlog option, which is deprecated and meant to be removed in a future release. If you use --resultlog, please try out pytest-reportlog and provide feedback.

    • #4730: When sys.pycache_prefix (Python 3.8+) is set, it will be used by pytest to cache test files changed by the assertion rewriting mechanism.

      This makes it easier to benefit of cached .pyc files even on file systems without permissions.

    • #5515: Allow selective auto-indentation of multiline log messages.

      Adds command line option --log-auto-indent, config option log_auto_indent and support for per-entry configuration of

    ... (truncated)
    Changelog

    Sourced from pytest's changelog.

    pytest 5.3.0 (2019-11-19)

    Deprecations

    • #6179: The default value of junit_family option will change to xunit2 in pytest 6.0, given that this is the version supported by default in modern tools that manipulate this type of file.

      In order to smooth the transition, pytest will issue a warning in case the --junitxml option is given in the command line but junit_family is not explicitly configured in pytest.ini.

      For more information, see the docs.

    Features

    • #4488: The pytest team has created the pytest-reportlog plugin, which provides a new --report-log=FILE option that writes report logs into a file as the test session executes.

      Each line of the report log contains a self contained JSON object corresponding to a testing event, such as a collection or a test result report. The file is guaranteed to be flushed after writing each line, so systems can read and process events in real-time.

      The plugin is meant to replace the --resultlog option, which is deprecated and meant to be removed in a future release. If you use --resultlog, please try out pytest-reportlog and provide feedback.

    • #4730: When sys.pycache_prefix (Python 3.8+) is set, it will be used by pytest to cache test files changed by the assertion rewriting mechanism.

      This makes it easier to benefit of cached .pyc files even on file systems without permissions.

    • #5515: Allow selective auto-indentation of multiline log messages.

      Adds command line option --log-auto-indent, config option log_auto_indent and support for per-entry configuration of indentation behavior on calls to logging.log().

      Alters the default for auto-indention from on to off. This restores the older behavior that existed prior to v4.6.0. This reversion to earlier behavior was done because it is better to activate new features that may lead to broken tests explicitly rather than implicitly.

    • #5914: pytester learned two new functions, no_fnmatch_line and no_re_match_line.

      The functions are used to ensure the captured text does not match the given pattern.

      The previous idiom was to use re.match:

      assert re.match(pat, result.stdout.str()) is None
      

      Or the in operator:

      assert text in result.stdout.str()
      

      But the new functions produce best output on failure.

    • #6057: Added tolerances to complex values when printing pytest.approx.

    ... (truncated)
    Commits
    • be59827 Small fixes in the CHANGELOG for 5.3.0
    • 4b16b93 Preparing release version 5.3.0
    • 21622d0 Merge remote-tracking branch 'upstream/master' into release-5.3.0
    • d1e2d12 python: remove unused pytest_make_parametrize_id hookimpl (#6228)
    • f36ea24 Remove check for os.symlink, always there in py3+ (#6227)
    • 4804d4b python: remove unused pytest_make_parametrize_id hookimpl
    • b820b7e Merge pull request #6224 from blueyed/visit_Assert-minor-cleanup
    • 8d3e8b1 Revert "ci: use tox -vv" (#6226)
    • 63a23d8 Remove check for os.symlink, always there in py3+
    • eeeb196 Merge pull request #6202 from linw1995/fix_getmodpath
    • Additional commits viewable in compare view

    Dependabot compatibility score

    Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.

    If all status checks pass Dependabot will automatically merge this pull request.


    Dependabot commands and options

    You can trigger Dependabot actions by commenting on this PR:

    • @dependabot rebase will rebase this PR
    • @dependabot recreate will recreate this PR, overwriting any edits that have been made to it
    • @dependabot merge will merge this PR after your CI passes on it
    • @dependabot squash and merge will squash and merge this PR after your CI passes on it
    • @dependabot cancel merge will cancel a previously requested merge and block automerging
    • @dependabot reopen will reopen this PR if it is closed
    • @dependabot close will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
    • @dependabot ignore this major version will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)
    • @dependabot ignore this minor version will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)
    • @dependabot ignore this dependency will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)
    • @dependabot use these labels will set the current labels as the default for future PRs for this repo and language
    • @dependabot use these reviewers will set the current reviewers as the default for future PRs for this repo and language
    • @dependabot use these assignees will set the current assignees as the default for future PRs for this repo and language
    • @dependabot use this milestone will set the current milestone as the default for future PRs for this repo and language
    • @dependabot badge me will comment on this PR with code to add a "Dependabot enabled" badge to your readme

    Additionally, you can set the following in your Dependabot dashboard:

    • Update frequency (including time of day and day of week)
    • Pull request limits (per update run and/or open at any time)
    • Automerge options (never/patch/minor, and dev/runtime dependencies)
    • Out-of-range updates (receive only lockfile updates, if desired)
    • Security updates (receive only security updates, if desired)
    dependencies 
    opened by dependabot-preview[bot] 4
  • Bump simplejson from 3.17.2 to 3.18.0

    Bump simplejson from 3.17.2 to 3.18.0

    Bumps simplejson from 3.17.2 to 3.18.0.

    Release notes

    Sourced from simplejson's releases.

    v3.18.0

    Version 3.18.0 released 2022-11-14

    • Allow serialization of classes that implement for_json or _asdict by ignoring TypeError when those methods are called simplejson/simplejson#302
    • Raise JSONDecodeError instead of ValueError in invalid unicode escape sequence edge case simplejson/simplejson#298

    v3.17.6

    Version 3.17.6 released 2021-11-15

    v3.17.5

    Version 3.17.5 released 2021-08-23

    • Fix the C extension module to harden is_namedtuple against looks-a-likes such as Mocks. Also prevent dict encoding from causing an unraised SystemError when encountering a non-Dict. Noticed by running user tests against a CPython interpreter with C asserts enabled (COPTS += -UNDEBUG). simplejson/simplejson#284

    v3.17.4

    Version 3.17.4 released 2021-08-19

    v3.17.3

    Version 3.17.3 released 2021-07-09

    Changelog

    Sourced from simplejson's changelog.

    Version 3.18.0 released 2022-11-14

    • Allow serialization of classes that implement for_json or _asdict by ignoring TypeError when those methods are called simplejson/simplejson#302
    • Raise JSONDecodeError instead of ValueError in invalid unicode escape sequence edge case simplejson/simplejson#298

    Version 3.17.6 released 2021-11-15

    Version 3.17.5 released 2021-08-23

    • Fix the C extension module to harden is_namedtuple against looks-a-likes such as Mocks. Also prevent dict encoding from causing an unraised SystemError when encountering a non-Dict. Noticed by running user tests against a CPython interpreter with C asserts enabled (COPTS += -UNDEBUG). simplejson/simplejson#284

    Version 3.17.4 released 2021-08-19

    Version 3.17.3 released 2021-07-09

    Version 3.17.2 released 2020-07-16

    Version 3.17.0 released 2019-11-17

    • Updated documentation to be Python 3 first, and have removed documentation notes about version changes that occurred more than five years ago. simplejson/simplejson#257

    ... (truncated)

    Commits

    Dependabot compatibility score

    Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.


    Dependabot commands and options

    You can trigger Dependabot actions by commenting on this PR:

    • @dependabot rebase will rebase this PR
    • @dependabot recreate will recreate this PR, overwriting any edits that have been made to it
    • @dependabot merge will merge this PR after your CI passes on it
    • @dependabot squash and merge will squash and merge this PR after your CI passes on it
    • @dependabot cancel merge will cancel a previously requested merge and block automerging
    • @dependabot reopen will reopen this PR if it is closed
    • @dependabot close will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
    • @dependabot ignore this major version will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)
    • @dependabot ignore this minor version will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)
    • @dependabot ignore this dependency will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)
    dependencies python 
    opened by dependabot[bot] 0
  • Bump regex from 1.3.1 to 1.5.6

    Bump regex from 1.3.1 to 1.5.6

    Bumps regex from 1.3.1 to 1.5.6.

    Changelog

    Sourced from regex's changelog.

    1.5.6 (2022-05-20)

    This release includes a few bug fixes, including a bug that produced incorrect matches when a non-greedy ? operator was used.

    1.5.5 (2022-03-08)

    This releases fixes a security bug in the regex compiler. This bug permits a vector for a denial-of-service attack in cases where the regex being compiled is untrusted. There are no known problems where the regex is itself trusted, including in cases of untrusted haystacks.

    1.5.4 (2021-05-06)

    This release fixes another compilation failure when building regex. This time, the fix is for when the pattern feature is enabled, which only works on nightly Rust. CI has been updated to test this case.

    1.5.3 (2021-05-01)

    This releases fixes a bug when building regex with only the unicode-perl feature. It turns out that while CI was building this configuration, it wasn't actually failing the overall build on a failed compilation.

    1.5.2 (2021-05-01)

    This release fixes a performance bug when Unicode word boundaries are used.

    ... (truncated)

    Commits

    Dependabot compatibility score

    Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.


    Dependabot commands and options

    You can trigger Dependabot actions by commenting on this PR:

    • @dependabot rebase will rebase this PR
    • @dependabot recreate will recreate this PR, overwriting any edits that have been made to it
    • @dependabot merge will merge this PR after your CI passes on it
    • @dependabot squash and merge will squash and merge this PR after your CI passes on it
    • @dependabot cancel merge will cancel a previously requested merge and block automerging
    • @dependabot reopen will reopen this PR if it is closed
    • @dependabot close will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
    • @dependabot ignore this major version will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)
    • @dependabot ignore this minor version will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)
    • @dependabot ignore this dependency will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself) You can disable automated security fix PRs for this repo from the Security Alerts page.
    dependencies rust 
    opened by dependabot[bot] 0
  • Bump flake8 from 3.9.1 to 3.9.2

    Bump flake8 from 3.9.1 to 3.9.2

    Bumps flake8 from 3.9.1 to 3.9.2.

    Commits

    Dependabot compatibility score

    Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.


    Dependabot commands and options

    You can trigger Dependabot actions by commenting on this PR:

    • @dependabot rebase will rebase this PR
    • @dependabot recreate will recreate this PR, overwriting any edits that have been made to it
    • @dependabot merge will merge this PR after your CI passes on it
    • @dependabot squash and merge will squash and merge this PR after your CI passes on it
    • @dependabot cancel merge will cancel a previously requested merge and block automerging
    • @dependabot reopen will reopen this PR if it is closed
    • @dependabot close will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
    dependencies 
    opened by dependabot[bot] 0
  • Bump autopep8 from 1.5.6 to 1.5.7

    Bump autopep8 from 1.5.6 to 1.5.7

    Bumps autopep8 from 1.5.6 to 1.5.7.

    Release notes

    Sourced from autopep8's releases.

    v1.5.7

    Change

    • #597: disallow 0 for indent-size option
    • #595: exit code is 99 when error occured cli option parsing

    Bug Fix

    • #591, #592: exit code correctly on permission denied failure
    Commits
    • 32c78a3 version 1.5.7
    • a0e00a8 fix invalid regex
    • 9274aac refactoring
    • 745faa8 Merge pull request #597 from hhatto/change-indent-size-option-zero-is-not-all...
    • 283e799 Merge branch 'master' into change-indent-size-option-zero-is-not-allowed
    • 64087d9 change: disallow 0 for indent-size option
    • 47690b0 Merge pull request #596 from howeaj/patch-1
    • 85d7c81 Show more options in example config
    • 3cf5bfe Merge pull request #595 from hhatto/fix-exit-code-99-with-cli-option-parse-error
    • a4f0e86 fix unit test
    • Additional commits viewable in compare view

    Dependabot compatibility score

    Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.


    Dependabot commands and options

    You can trigger Dependabot actions by commenting on this PR:

    • @dependabot rebase will rebase this PR
    • @dependabot recreate will recreate this PR, overwriting any edits that have been made to it
    • @dependabot merge will merge this PR after your CI passes on it
    • @dependabot squash and merge will squash and merge this PR after your CI passes on it
    • @dependabot cancel merge will cancel a previously requested merge and block automerging
    • @dependabot reopen will reopen this PR if it is closed
    • @dependabot close will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
    dependencies 
    opened by dependabot[bot] 0
  • [0.2.4] Low-level details in JSONDecodeError message by mistake?

    [0.2.4] Low-level details in JSONDecodeError message by mistake?

    Hi!

    I'm happy to find that hyperjson rejects single surrogates as invalid characters but the exception text looks more low-level than expected. Is this a bug? Can the exception message be made more highlevel like "single surrogates not allowed"?

    In [8]: hyperjson.__version__
    Out[8]: '0.2.4'
    
    In [9]: hyperjson.loads('"\\ud800"')
    [..]
    JSONDecodeError: Value: PyObject(0x7f481b3a1530), Error: PyErr { type: Py(0x7f48262225c0, PhantomData) }: line 1 column 1 (char 0)
    

    Thanks and best, Sebastian

    opened by hartwork 0
  • Speed up boolean encoding/decoding

    Speed up boolean encoding/decoding

    From our benchmarks we can see that we are consistently slower than everyone else when serializing/deserializing boolean values. We should fix that.

    orjson is using an unsafe block to create a reference to a boolean: https://github.com/ijl/orjson/blob/03d55e99a953ce93cedc05f03e4b63b0bcbbcc7a/src/decode.rs#L81-L96

    This avoids additional allocations. For comparison, this is our code at the moment:

    https://github.com/mre/hyperjson/blob/ded13b4100638aa32fe19dc477f5cfe3e704893c/src/lib.rs#L475-L480

    I wonder if we could achieve comparable performance without using unsafe. @konstin, any idea? Maybe there was a recent development in pyo3 that we could leverage here?

    enhancement help wanted good first issue hacktoberfest 
    opened by mre 1
Owner
Matthias
Curious person. Maker. Rustacean. Oxidizing things.
Matthias
原神抽卡记录数据集-Genshin Impact gacha data

提要 持续收集原神抽卡记录中 可以使用抽卡记录导出工具导出抽卡记录的json,将json文件发送至[email protected],我会在清除个人信息后

117 Dec 27, 2022
PyTorch code for EMNLP 2019 paper "LXMERT: Learning Cross-Modality Encoder Representations from Transformers".

LXMERT: Learning Cross-Modality Encoder Representations from Transformers Our servers break again :(. I have updated the links so that they should wor

Hao Tan 838 Dec 19, 2022
Linking data between GBIF, Biodiverse, and Open Tree of Life

GBIF-biodiverse-OpenTree Linking data between GBIF, Biodiverse, and Open Tree of Life The python scripts will rely on opentree and Dendropy. To set up

2 Oct 03, 2022
Repository for the paper: VoiceMe: Personalized voice generation in TTS

🗣 VoiceMe: Personalized voice generation in TTS Abstract Novel text-to-speech systems can generate entirely new voices that were not seen during trai

Pol van Rijn 80 Dec 29, 2022
Web mining module for Python, with tools for scraping, natural language processing, machine learning, network analysis and visualization.

Pattern Pattern is a web mining module for Python. It has tools for: Data Mining: web services (Google, Twitter, Wikipedia), web crawler, HTML DOM par

Computational Linguistics Research Group 8.4k Dec 30, 2022
中文无监督SimCSE Pytorch实现

A PyTorch implementation of unsupervised SimCSE SimCSE: Simple Contrastive Learning of Sentence Embeddings 1. 用法 无监督训练 python train_unsup.py ./data/ne

99 Dec 23, 2022
justCTF [*] 2020 challenges sources

justCTF [*] 2020 This repo contains sources for justCTF [*] 2020 challenges hosted by justCatTheFish. TLDR: Run a challenge with ./run.sh (requires Do

justCatTheFish 25 Dec 27, 2022
Code for the Findings of NAACL 2022(Long Paper): AdapterBias: Parameter-efficient Token-dependent Representation Shift for Adapters in NLP Tasks

AdapterBias: Parameter-efficient Token-dependent Representation Shift for Adapters in NLP Tasks arXiv link: upcoming To be published in Findings of NA

Allen 16 Nov 12, 2022
A Persian Image Captioning model based on Vision Encoder Decoder Models of the transformers🤗.

Persian-Image-Captioning We fine-tuning the Vision Encoder Decoder Model for the task of image captioning on the coco-flickr-farsi dataset. The implem

Hamtech-ai 15 Aug 25, 2022
NLP made easy

GluonNLP: Your Choice of Deep Learning for NLP GluonNLP is a toolkit that helps you solve NLP problems. It provides easy-to-use tools that helps you l

Distributed (Deep) Machine Learning Community 2.5k Jan 04, 2023
Creating an LSTM model to generate music

Music-Generation Creating an LSTM model to generate music music-generator Used to create basic sin wave sounds music-ai Contains the functions to conv

Jerin Joseph 2 Dec 02, 2021
LegalNLP - Natural Language Processing Methods for the Brazilian Legal Language

LegalNLP - Natural Language Processing Methods for the Brazilian Legal Language ⚖️ The library of Natural Language Processing for Brazilian legal lang

Felipe Maia Polo 125 Dec 20, 2022
nlpcommon is a python Open Source Toolkit for text classification.

nlpcommon nlpcommon, Python Text Tool. Guide Feature Install Usage Dataset Contact Cite Reference Feature nlpcommon is a python Open Source

xuming 3 May 29, 2022
A Chinese to English Neural Model Translation Project

ZH-EN NMT Chinese to English Neural Machine Translation This project is inspired by Stanford's CS224N NMT Project Dataset used in this project: News C

Zhenbang Feng 29 Nov 26, 2022
DANeS is an open-source E-newspaper dataset by collaboration between DATASET JSC (dataset.vn) and AIV Group (aivgroup.vn)

DANeS - Open-source E-newspaper dataset Source: Technology vector created by macrovector - www.freepik.com. DANeS is an open-source E-newspaper datase

DATASET .JSC 64 Aug 17, 2022
SentimentArcs: a large ensemble of dozens of sentiment analysis models to analyze emotion in text over time

SentimentArcs - Emotion in Text An end-to-end pipeline based on Jupyter notebooks to detect, extract, process and anlayze emotion over time in text. E

jon_chun 14 Dec 19, 2022
Creating a chess engine using GPT-3

GPT3Chess Creating a chess engine using GPT-3 Code for my article : https://towardsdatascience.com/gpt-3-play-chess-d123a96096a9 My game (white) vs GP

19 Dec 17, 2022
Download videos from YouTube/Twitch/Twitter right in the Windows Explorer, without installing any shady shareware apps

youtube-dl and ffmpeg Windows Explorer Integration Download videos from YouTube/Twitch/Twitter and more (any platform that is supported by youtube-dl)

Wolfgang 226 Dec 30, 2022
NLP - Machine learning

Flipkart-product-reviews NLP - Machine learning About Product reviews is an essential part of an online store like Flipkart’s branding and marketing.

Harshith VH 1 Oct 29, 2021
Code for paper "Which Training Methods for GANs do actually Converge? (ICML 2018)"

GAN stability This repository contains the experiments in the supplementary material for the paper Which Training Methods for GANs do actually Converg

Lars Mescheder 884 Nov 11, 2022