# unihan-db · [![Python Package](https://img.shields.io/pypi/v/unihan-db.svg)](https://pypi.org/project/unihan-db/) [![License](https://img.shields.io/github/license/cihai/unihan-db.svg)](https://github.com/cihai/unihan-db/blob/master/LICENSE) [![Code Coverage](https://codecov.io/gh/cihai/unihan-db/branch/master/graph/badge.svg)](https://codecov.io/gh/cihai/unihan-db)
Database [SQLAlchemy](https://www.sqlalchemy.org/) models for
[UNIHAN](http://www.unicode.org/charts/unihan.html). Part of the [cihai](https://cihai.git-pull.com)
project. Powered by [unihan-etl](https://unihan-etl.git-pull.com). See also:
[libUnihan](http://libunihan.sourceforge.net/).
By default, unihan-db creates a SQLite database in an
[XDG data directory](https://standards.freedesktop.org/basedir-spec/basedir-spec-latest.html). You
can specify a custom database destination by passing a database url into
[get_session](http://unihan-db.git-pull.com/api.html#unihan_db.bootstrap.get_session).
## Example usage
```python
#!/usr/bin/env python
"""Example for bootstrapping UNIHAN DB and print out a row."""
import pprint
from sqlalchemy.sql.expression import func
from unihan_db import bootstrap
from unihan_db.tables import Unhn
session = bootstrap.get_session()
bootstrap.bootstrap_unihan(session)
random_row_query = session.query(Unhn).order_by(func.random()).limit(1)
assert random_row_query is not None
random_row = random_row_query.first()
pprint.pprint(bootstrap.to_dict(random_row))
pprint.pprint(random_row.to_dict()) # type:ignore
```
Run:
$ ./examples/01_bootstrap.py
Output:
```python
{'char': '鎷',
'kCantonese': [{'char_id': '鎷', 'definition': 'maa5', 'id': 24035}],
'kDefinition': [],
'kHanYu': [{'char_id': '鎷',
'id': 24014,
'locations': [{'character': 5,
'generic_indice_id': 24014,
'generic_reading_id': None,
'id': 42170,
'page': 4237,
'virtual': 0,
'volume': 6}],
'type': 'kHanYu'}],
'kHanyuPinyin': [{'char_id': '鎷',
'id': 18090,
'locations': [{'character': 5,
'generic_indice_id': None,
'generic_reading_id': 18090,
'id': 42169,
'page': 4237,
'virtual': 0,
'volume': 6}],
'readings': [{'generic_reading_id': 18090,
'id': 26695,
'reading': 'mǎ'}],
'type': 'kHanyuPinyin'}],
'kMandarin': [{'char_id': '鎷', 'hans': 'mǎ', 'hant': 'mǎ', 'id': 23486}],
'ucn': 'U+93B7'}
```
## Developing
```console
$ git clone https://github.com/cihai/unihan-etl.git
```
```console
$ cd unihan-etl
```
[Bootstrap your environment and learn more about contributing](https://cihai.git-pull.com/contributing/). We use the same conventions / tools across all cihai projects: `pytest`, `sphinx`, `mypy`, `ruff`, `tmuxp`, and file watcher helpers (e.g. `entr(1)`).
## Python versions
- 0.8.0:
- Last Python 3.7 release
- Last SQLAlchemy 1.3 release
## More information
[![Docs](https://github.com/cihai/unihan-db/workflows/docs/badge.svg)](https://unihan-db.git-pull.com/)
[![Build Status](https://github.com/cihai/unihan-db/workflows/tests/badge.svg)](https://github.com/cihai/unihan-db/actions?query=workflow%3A%22tests%22)
Raw data
{
"_id": null,
"home_page": null,
"name": "unihan-db",
"maintainer": null,
"docs_url": null,
"requires_python": "<4.0,>=3.9",
"maintainer_email": null,
"keywords": "chinese, cjk, database, japanese, sql, sqlalchemy, unihan",
"author": null,
"author_email": "Tony Narlock <tony@git-pull.com>",
"download_url": "https://files.pythonhosted.org/packages/43/25/f99ccc47b161eaa1fd1f1837fac0d70370ae733b7078139b0ba222dafdcf/unihan_db-0.18.0.tar.gz",
"platform": null,
"description": "# unihan-db · [![Python Package](https://img.shields.io/pypi/v/unihan-db.svg)](https://pypi.org/project/unihan-db/) [![License](https://img.shields.io/github/license/cihai/unihan-db.svg)](https://github.com/cihai/unihan-db/blob/master/LICENSE) [![Code Coverage](https://codecov.io/gh/cihai/unihan-db/branch/master/graph/badge.svg)](https://codecov.io/gh/cihai/unihan-db)\n\nDatabase [SQLAlchemy](https://www.sqlalchemy.org/) models for\n[UNIHAN](http://www.unicode.org/charts/unihan.html). Part of the [cihai](https://cihai.git-pull.com)\nproject. Powered by [unihan-etl](https://unihan-etl.git-pull.com). See also:\n[libUnihan](http://libunihan.sourceforge.net/).\n\nBy default, unihan-db creates a SQLite database in an\n[XDG data directory](https://standards.freedesktop.org/basedir-spec/basedir-spec-latest.html). You\ncan specify a custom database destination by passing a database url into\n[get_session](http://unihan-db.git-pull.com/api.html#unihan_db.bootstrap.get_session).\n\n## Example usage\n\n```python\n#!/usr/bin/env python\n\"\"\"Example for bootstrapping UNIHAN DB and print out a row.\"\"\"\nimport pprint\n\nfrom sqlalchemy.sql.expression import func\n\nfrom unihan_db import bootstrap\nfrom unihan_db.tables import Unhn\n\nsession = bootstrap.get_session()\n\nbootstrap.bootstrap_unihan(session)\n\nrandom_row_query = session.query(Unhn).order_by(func.random()).limit(1)\n\nassert random_row_query is not None\n\nrandom_row = random_row_query.first()\n\npprint.pprint(bootstrap.to_dict(random_row))\n\npprint.pprint(random_row.to_dict()) # type:ignore\n```\n\nRun:\n\n $ ./examples/01_bootstrap.py\n\nOutput:\n\n```python\n{'char': '\u93b7',\n'kCantonese': [{'char_id': '\u93b7', 'definition': 'maa5', 'id': 24035}],\n'kDefinition': [],\n'kHanYu': [{'char_id': '\u93b7',\n 'id': 24014,\n 'locations': [{'character': 5,\n 'generic_indice_id': 24014,\n 'generic_reading_id': None,\n 'id': 42170,\n 'page': 4237,\n 'virtual': 0,\n 'volume': 6}],\n 'type': 'kHanYu'}],\n'kHanyuPinyin': [{'char_id': '\u93b7',\n 'id': 18090,\n 'locations': [{'character': 5,\n 'generic_indice_id': None,\n 'generic_reading_id': 18090,\n 'id': 42169,\n 'page': 4237,\n 'virtual': 0,\n 'volume': 6}],\n 'readings': [{'generic_reading_id': 18090,\n 'id': 26695,\n 'reading': 'm\u01ce'}],\n 'type': 'kHanyuPinyin'}],\n'kMandarin': [{'char_id': '\u93b7', 'hans': 'm\u01ce', 'hant': 'm\u01ce', 'id': 23486}],\n'ucn': 'U+93B7'}\n```\n\n## Developing\n\n```console\n$ git clone https://github.com/cihai/unihan-etl.git\n```\n\n```console\n$ cd unihan-etl\n```\n\n[Bootstrap your environment and learn more about contributing](https://cihai.git-pull.com/contributing/). We use the same conventions / tools across all cihai projects: `pytest`, `sphinx`, `mypy`, `ruff`, `tmuxp`, and file watcher helpers (e.g. `entr(1)`).\n\n## Python versions\n\n- 0.8.0:\n - Last Python 3.7 release\n - Last SQLAlchemy 1.3 release\n\n## More information\n\n[![Docs](https://github.com/cihai/unihan-db/workflows/docs/badge.svg)](https://unihan-db.git-pull.com/)\n[![Build Status](https://github.com/cihai/unihan-db/workflows/tests/badge.svg)](https://github.com/cihai/unihan-db/actions?query=workflow%3A%22tests%22)\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "SQLAlchemy models for UNIHAN CJK database",
"version": "0.18.0",
"project_urls": {
"Bug Tracker": "https://github.com/cihai/unihan-db/issues",
"Documentation": "https://unihan-db.git-pull.com",
"Release notes": "https://github.com/cihai/unihan-db/blob/master/CHANGES",
"Repository": "https://github.com/cihai/unihan-db"
},
"split_keywords": [
"chinese",
" cjk",
" database",
" japanese",
" sql",
" sqlalchemy",
" unihan"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "d328deeb9da81c2ae3b51be7911725b57c0e7f17707c96a2eb4defba2a4ba1dd",
"md5": "6515a8846887276b6c238593bbee3bc9",
"sha256": "12a2bd5f22f9ef7cf583fd47c8df841fa3317da048299fb41eaf9fe1c8890e7a"
},
"downloads": -1,
"filename": "unihan_db-0.18.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "6515a8846887276b6c238593bbee3bc9",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0,>=3.9",
"size": 11840,
"upload_time": "2024-12-21T12:20:27",
"upload_time_iso_8601": "2024-12-21T12:20:27.397544Z",
"url": "https://files.pythonhosted.org/packages/d3/28/deeb9da81c2ae3b51be7911725b57c0e7f17707c96a2eb4defba2a4ba1dd/unihan_db-0.18.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "4325f99ccc47b161eaa1fd1f1837fac0d70370ae733b7078139b0ba222dafdcf",
"md5": "bee98e80ea4187bdef09219657956b65",
"sha256": "e00bc28e85247e77d0ca3bb821e02ce7ec14da74390e2ee00947e2bebbc3194a"
},
"downloads": -1,
"filename": "unihan_db-0.18.0.tar.gz",
"has_sig": false,
"md5_digest": "bee98e80ea4187bdef09219657956b65",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0,>=3.9",
"size": 178894,
"upload_time": "2024-12-21T12:20:29",
"upload_time_iso_8601": "2024-12-21T12:20:29.876328Z",
"url": "https://files.pythonhosted.org/packages/43/25/f99ccc47b161eaa1fd1f1837fac0d70370ae733b7078139b0ba222dafdcf/unihan_db-0.18.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-21 12:20:29",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "cihai",
"github_project": "unihan-db",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"tox": true,
"lcname": "unihan-db"
}