Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/unitedstates/uscode
A working parser for the US Code's hierarchy, and a work-in-progress parser for the full content.
https://github.com/unitedstates/uscode
Last synced: about 2 months ago
JSON representation
A working parser for the US Code's hierarchy, and a work-in-progress parser for the full content.
- Host: GitHub
- URL: https://github.com/unitedstates/uscode
- Owner: unitedstates
- License: cc0-1.0
- Created: 2012-09-10T20:27:57.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2014-06-08T05:08:41.000Z (over 10 years ago)
- Last Synced: 2024-08-05T03:02:10.703Z (5 months ago)
- Language: Python
- Homepage:
- Size: 9.61 MB
- Stars: 104
- Watchers: 22
- Forks: 20
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-democracy-data - uscode - A working parser for the US Code's hierarchy, and a work-in-progress parser for the full content. (:book: Legislative records)
README
## Parsing the US Code
A parser for the US Code's structure, and a work-in-progress parser for the US Code's full content.
### Setup
Create a virtual environment:
```bash
virtualenv virt
source virt/bin/activate
pip install -r requirements.txt
```### Getting the structure of the Code
To output the hierarchy of the US Code to STDOUT, in JSON:
```bash
./run structure
```The script will first download the
Options:
* `--year`: "uscprelim" (the default), or a specific year version of the Code (e.g. "2011")
* `--title`: Do only a specific title (e.g. "5", "5a", "25")
* `--sections`: Return a flat hierarchy of only titles and sections (no intervening layers)
* `--debug`: Output debug messages only, and no JSON output (dry run)
* `--force`: Force a re-download of the US Code. Use this flag if you're automatically running the script at an interval.Example:
```json
[
{
"level": "title",
"name": "GENERAL PROVISIONS",
"number": "1",
"subparts": [
{
"level": "chapter",
"name": "RULES OF CONSTRUCTION",
"number": "1",
"subparts": [
{
"citation": "usc/1/1",
"level": "section",
"name": "Words denoting number, gender, and so forth",
"number": "1"
},
{
"citation": "usc/1/2",
"level": "section",
"name": "\u201cCounty\u201d as including \u201cparish\u201d, and so forth",
"number": "2"
},
...
]
}
]
}
]
```### Getting the content of the Code (work-in-progress)
To get at the content of the Code:
* Run `download/gpolocator.sh 2011` to download all GPO Locator files for 2011.
* Run download/pdf.sh to download all pdf files for 2011.Run the debug script with the title as the first argument and the offset of the parsed node in the parsed title (yes, that makes no sense--just enter a number, like 3).
```bash
source virt/bin/activate # if not already activated
./run debug title=[title] offset=[offset]
```So to view title 11, section 1, which is the definitions section of the bankruptcy code, run:
```bash
./run debug title=11 offset=3
```## Public domain
This project is [dedicated to the public domain](LICENSE). As spelled out in [CONTRIBUTING](CONTRIBUTING.md):
> The project is in the public domain within the United States, and copyright and related rights in the work worldwide are waived through the [CC0 1.0 Universal public domain dedication](http://creativecommons.org/publicdomain/zero/1.0/).
> All contributions to this project will be released under the CC0 dedication. By submitting a pull request, you are agreeing to comply with this waiver of copyright interest.