sumire


Namesumire JSON
Version 1.0.2 PyPI version JSON
download
home_page
SummaryScikit-learn compatible Japanese text vectorizer for CPU-based Japanese natural language processing.
upload_time2024-01-31 14:38:04
maintainer
docs_urlNone
author
requires_python>=3.9
license
keywords japanese nlp natural language processing scikit-learn tokenizer
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # sumire

**形態素解析器などの事前インストールなし**で使える, 
CPUベースの日本語自然言語処理のための,
Scikit-learn互換の日本語の単語分割器と, テキストのベクトル化ツール.

[![PyPI - Version](https://img.shields.io/pypi/v/sumire.svg)](https://pypi.org/project/sumire)
[![PyPI - Python Version](https://img.shields.io/pypi/pyversions/sumire.svg)](https://pypi.org/project/sumire)
![Lint](https://github.com/reiven-c-t/sumire/actions/workflows/python-lint.yml/badge.svg)
![Test](https://github.com/reiven-c-t/sumire/actions/workflows/python-test.yml/badge.svg)
![Coverage](https://img.shields.io/endpoint?url=https://gist.githubusercontent.com/reiven-c-t/4300c0ff006aab09e6733925efbbf517/raw/3316d071e93ee9de175dc83086870cbd082c0b65/gistfile1.txt)

-----

**Table of Contents**

- [sumire](#sumire)
  * [Installation](#installation)
    + [pre-requirements](#pre-requirements)
  * [Usage](#usage)
      - [Tokenizer usage](#tokenizer-usage)
      - [Vectorizer usage](#vectorizer-usage)
  * [Development background](#development-background)
      - [Unmotivated development tasks (at this moment.)](#unmotivated-development-tasks-at-this-moment)
      - [Roadmap (motivated development tasks)](#roadmap-motivated-development-tasks)
    + [Coding rule](#coding-rule)
  * [License](#license)
  * [Acknowledgements (Dependent libraries, data, and models.)](#acknowledgements-dependent-libraries-data-and-models)

## Installation

### pre-requirements

- Tested OS: ubuntu 22.04.
- python >=3.9
- make
- cmake
- git 

<!--TODO: test. MeCab-IPAdic-Neologdや, MeCab-Unidic-Neologdを使う場合, もしかしたらgitアカウントにログインが必要かもしれない. -->

```shell
# Jumanpp dependencies.
sudo apt update -y;
sudo apt install -y cmake libeigen3-dev libprotobuf-dev protobuf-c-compiler;
```

`pip install sumire`だけで, **MeCabもJumanppも, インストールなしで**使えます.
MeCabやJumanppの実行バイナリや各種辞書がなければ, `$HOME/.local/sumire/`にTokenizerをインスタンス化した時にインストールされます.

## Usage

#### Tokenizer usage

```python
from sumire.tokenizer import MecabTokenizer, JumanppTokenizer


text = "これはテスト文です。" 
texts = ["これはテスト文です。", "別のテキストもトークン化します。"]

mecab = MecabTokenizer("unidic-lite")
text_mecab_tokenized = mecab.tokenize(text)
texts_mecab_tokenized = mecab.tokenize(texts)

jumanpp = JumanppTokenizer()
jumanpp.tokenize(text)
text_jumanpp_tokenized = jumanpp.tokenize(text)
texts_jumanpp_tokenized = jumanpp.tokenize(texts)
```

#### Vectorizer usage

```python
from sumire.tokenizer.mecab import MecabTokenizer
from sumire.vectorizer.count import CountVectorizer
from sumire.vectorizer.swem import W2VSWEMVectorizer
from sumire.vectorizer.transformer_emb import TransformerEmbeddingVectorizer

texts = ["これはテスト文です。", "別のテキストもトークン化します。"]

count_vectorizer = CountVectorizer()  # this automatically use MecabTokenizer()
swem_vectorizer = W2VSWEMVectorizer()
bert_cls_vectorizer = TransformerEmbeddingVectorizer()

# fit and transform at the same time. (Of course, you can .fit() and .transform() separately!)
count_vectorized = count_vectorizer.fit_transform(texts)
swem_vectorized = swem_vectorizer.fit_transform(texts)
bert_cls_vectorized = bert_cls_vectorizer.fit_transform(texts)

# save and load vectorizer.
count_vectorizer.save_pretrained("path/to/count_vectorizer")
count_vectorizer = CountVectorizer.from_pretrained("path/to/count_vectorizer")
swem_vectorizer.save_pretrained("path/to/swem_vectorizer")
swem_vectorizer = W2VSWEMVectorizer.from_pretrained("path/to/swem_vectorizer")
bert_cls_vectorizer.save_pretrained("path/to/bert_cls_vectorizer")
bert_cls_vectorizer = TransformerEmbeddingVectorizer.from_pretrained("path/to/beert_cls_vectorizer")
```

各単語分割器や文分散表現モジュールの詳細なドキュメントは[ドキュメントページ](https://reiven-c-t.github.io/sumire/)を参照してください.
また, Transformersやgensimの動作済みmodelの情報は, `/sumire/resources/model_card`を参照してください.


## Development background

LLMの隆盛に伴い, 検索, 感情分析, その他テキスト分類・回帰などの日本語のNLPの実用タスクへの注目も高まりつつあります.
これらの基本的なタスクにおいて, 日本語のテキストを単語分割や, 単語や文の分散表現を得ることは, 最も基礎的な処理の一つです.
LLMの時代において, BERTなどの事前訓練済みTransformerモデルや, Open AI APIによるEmbeddingsは,
テキスト分散表現技術において最も重要な技術であることはいうまでもなく, また, 簡単に実装できるといえば実装できます. 

しかし, 実用の現場において, BERTや, OpenAI APIなどの, 
高価なGPUが必要な手法や, 1 Queryごとに費用が発生するAPIを用いた最先端の手法を使うことは, 計算量・運用コストの両面から負荷が軽いとはいえません.
また, データセット構築段階などのプロジェクトの初期段階での概念実証 (PoC) において, 
辞書データや形態素解析器の~~めんどくさい~~インストール作業や,
それぞれやや異なるAPIのメソッドやプロパティを調べながら作業を行うのは少しばかり手間です.

これらの点を踏まえて, GPUがあるとは限らない手元環境で, 
PoCにおけるモデリング・分析部分へ速やかに注力できように,
Scikit-learnのように, 機能ごとに統一的なAPIインターフェースで, 
テキストを与えればとりあえず色々な文の分散表現を取得できるライブラリを開発しました.

#### Unmotivated development tasks (at this moment.)

- Open-AI Embedding modelを使うこと. (高い.)
- 事前訓練済みTransformerモデルによるEmbeddingについて, GPUが必要なチューニング機能を実装すること. (手元にGPUがない.)
- 実行速度のためにライブラリ内部の可読性を大きく下げること. 
  - 小規模なPoCにおいて, コードの実行速度より, 実装速度のほうが重要だと考えています.
  - PoC後の大規模な運用にて, 速度やディスク容量が問題になった場合があれば, 
    本ライブラリ中の不要な処理をそれぞれの開発者が削除したりカスタマイズしやすいように, 可読性を維持したいです.


#### Roadmap (motivated development tasks)

- vectorizer inputsのdecode().
- Google colabでの動作環境検証.

### Coding rule

<https://pep8-ja.readthedocs.io/ja/latest/>


## License

`sumire` is distributed under the terms of the MIT License. 


## Acknowledgements (Dependent libraries, data, and models.)

See `dependent_licenses.csv`.
            

Raw data

            {
    "_id": null,
    "home_page": "",
    "name": "sumire",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": "",
    "keywords": "Japanese,NLP,Natural Language Processing,Scikit-learn,Tokenizer",
    "author": "",
    "author_email": "\"a.k.a.underfirst\" <a.k.a.underfirst@mail.com>",
    "download_url": "https://files.pythonhosted.org/packages/79/73/f6ac3c93d52d844388ffaf2827718b60edc550b00e1d4a613a60c26ac8bd/sumire-1.0.2.tar.gz",
    "platform": null,
    "description": "# sumire\n\n**\u5f62\u614b\u7d20\u89e3\u6790\u5668\u306a\u3069\u306e\u4e8b\u524d\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u306a\u3057**\u3067\u4f7f\u3048\u308b, \nCPU\u30d9\u30fc\u30b9\u306e\u65e5\u672c\u8a9e\u81ea\u7136\u8a00\u8a9e\u51e6\u7406\u306e\u305f\u3081\u306e,\nScikit-learn\u4e92\u63db\u306e\u65e5\u672c\u8a9e\u306e\u5358\u8a9e\u5206\u5272\u5668\u3068, \u30c6\u30ad\u30b9\u30c8\u306e\u30d9\u30af\u30c8\u30eb\u5316\u30c4\u30fc\u30eb.\n\n[![PyPI - Version](https://img.shields.io/pypi/v/sumire.svg)](https://pypi.org/project/sumire)\n[![PyPI - Python Version](https://img.shields.io/pypi/pyversions/sumire.svg)](https://pypi.org/project/sumire)\n![Lint](https://github.com/reiven-c-t/sumire/actions/workflows/python-lint.yml/badge.svg)\n![Test](https://github.com/reiven-c-t/sumire/actions/workflows/python-test.yml/badge.svg)\n![Coverage](https://img.shields.io/endpoint?url=https://gist.githubusercontent.com/reiven-c-t/4300c0ff006aab09e6733925efbbf517/raw/3316d071e93ee9de175dc83086870cbd082c0b65/gistfile1.txt)\n\n-----\n\n**Table of Contents**\n\n- [sumire](#sumire)\n  * [Installation](#installation)\n    + [pre-requirements](#pre-requirements)\n  * [Usage](#usage)\n      - [Tokenizer usage](#tokenizer-usage)\n      - [Vectorizer usage](#vectorizer-usage)\n  * [Development background](#development-background)\n      - [Unmotivated development tasks (at this moment.)](#unmotivated-development-tasks-at-this-moment)\n      - [Roadmap (motivated development tasks)](#roadmap-motivated-development-tasks)\n    + [Coding rule](#coding-rule)\n  * [License](#license)\n  * [Acknowledgements (Dependent libraries, data, and models.)](#acknowledgements-dependent-libraries-data-and-models)\n\n## Installation\n\n### pre-requirements\n\n- Tested OS: ubuntu 22.04.\n- python >=3.9\n- make\n- cmake\n- git \n\n<!--TODO: test. MeCab-IPAdic-Neologd\u3084, MeCab-Unidic-Neologd\u3092\u4f7f\u3046\u5834\u5408, \u3082\u3057\u304b\u3057\u305f\u3089git\u30a2\u30ab\u30a6\u30f3\u30c8\u306b\u30ed\u30b0\u30a4\u30f3\u304c\u5fc5\u8981\u304b\u3082\u3057\u308c\u306a\u3044. -->\n\n```shell\n# Jumanpp dependencies.\nsudo apt update -y;\nsudo apt install -y cmake libeigen3-dev libprotobuf-dev protobuf-c-compiler;\n```\n\n`pip install sumire`\u3060\u3051\u3067, **MeCab\u3082Jumanpp\u3082, \u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u306a\u3057\u3067**\u4f7f\u3048\u307e\u3059.\nMeCab\u3084Jumanpp\u306e\u5b9f\u884c\u30d0\u30a4\u30ca\u30ea\u3084\u5404\u7a2e\u8f9e\u66f8\u304c\u306a\u3051\u308c\u3070, `$HOME/.local/sumire/`\u306bTokenizer\u3092\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u5316\u3057\u305f\u6642\u306b\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3055\u308c\u307e\u3059.\n\n## Usage\n\n#### Tokenizer usage\n\n```python\nfrom sumire.tokenizer import MecabTokenizer, JumanppTokenizer\n\n\ntext = \"\u3053\u308c\u306f\u30c6\u30b9\u30c8\u6587\u3067\u3059\u3002\" \ntexts = [\"\u3053\u308c\u306f\u30c6\u30b9\u30c8\u6587\u3067\u3059\u3002\", \"\u5225\u306e\u30c6\u30ad\u30b9\u30c8\u3082\u30c8\u30fc\u30af\u30f3\u5316\u3057\u307e\u3059\u3002\"]\n\nmecab = MecabTokenizer(\"unidic-lite\")\ntext_mecab_tokenized = mecab.tokenize(text)\ntexts_mecab_tokenized = mecab.tokenize(texts)\n\njumanpp = JumanppTokenizer()\njumanpp.tokenize(text)\ntext_jumanpp_tokenized = jumanpp.tokenize(text)\ntexts_jumanpp_tokenized = jumanpp.tokenize(texts)\n```\n\n#### Vectorizer usage\n\n```python\nfrom sumire.tokenizer.mecab import MecabTokenizer\nfrom sumire.vectorizer.count import CountVectorizer\nfrom sumire.vectorizer.swem import W2VSWEMVectorizer\nfrom sumire.vectorizer.transformer_emb import TransformerEmbeddingVectorizer\n\ntexts = [\"\u3053\u308c\u306f\u30c6\u30b9\u30c8\u6587\u3067\u3059\u3002\", \"\u5225\u306e\u30c6\u30ad\u30b9\u30c8\u3082\u30c8\u30fc\u30af\u30f3\u5316\u3057\u307e\u3059\u3002\"]\n\ncount_vectorizer = CountVectorizer()  # this automatically use MecabTokenizer()\nswem_vectorizer = W2VSWEMVectorizer()\nbert_cls_vectorizer = TransformerEmbeddingVectorizer()\n\n# fit and transform at the same time. (Of course, you can .fit() and .transform() separately!)\ncount_vectorized = count_vectorizer.fit_transform(texts)\nswem_vectorized = swem_vectorizer.fit_transform(texts)\nbert_cls_vectorized = bert_cls_vectorizer.fit_transform(texts)\n\n# save and load vectorizer.\ncount_vectorizer.save_pretrained(\"path/to/count_vectorizer\")\ncount_vectorizer = CountVectorizer.from_pretrained(\"path/to/count_vectorizer\")\nswem_vectorizer.save_pretrained(\"path/to/swem_vectorizer\")\nswem_vectorizer = W2VSWEMVectorizer.from_pretrained(\"path/to/swem_vectorizer\")\nbert_cls_vectorizer.save_pretrained(\"path/to/bert_cls_vectorizer\")\nbert_cls_vectorizer = TransformerEmbeddingVectorizer.from_pretrained(\"path/to/beert_cls_vectorizer\")\n```\n\n\u5404\u5358\u8a9e\u5206\u5272\u5668\u3084\u6587\u5206\u6563\u8868\u73fe\u30e2\u30b8\u30e5\u30fc\u30eb\u306e\u8a73\u7d30\u306a\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u306f[\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u30da\u30fc\u30b8](https://reiven-c-t.github.io/sumire/)\u3092\u53c2\u7167\u3057\u3066\u304f\u3060\u3055\u3044.\n\u307e\u305f, Transformers\u3084gensim\u306e\u52d5\u4f5c\u6e08\u307fmodel\u306e\u60c5\u5831\u306f, `/sumire/resources/model_card`\u3092\u53c2\u7167\u3057\u3066\u304f\u3060\u3055\u3044.\n\n\n## Development background\n\nLLM\u306e\u9686\u76db\u306b\u4f34\u3044, \u691c\u7d22, \u611f\u60c5\u5206\u6790, \u305d\u306e\u4ed6\u30c6\u30ad\u30b9\u30c8\u5206\u985e\u30fb\u56de\u5e30\u306a\u3069\u306e\u65e5\u672c\u8a9e\u306eNLP\u306e\u5b9f\u7528\u30bf\u30b9\u30af\u3078\u306e\u6ce8\u76ee\u3082\u9ad8\u307e\u308a\u3064\u3064\u3042\u308a\u307e\u3059.\n\u3053\u308c\u3089\u306e\u57fa\u672c\u7684\u306a\u30bf\u30b9\u30af\u306b\u304a\u3044\u3066, \u65e5\u672c\u8a9e\u306e\u30c6\u30ad\u30b9\u30c8\u3092\u5358\u8a9e\u5206\u5272\u3084, \u5358\u8a9e\u3084\u6587\u306e\u5206\u6563\u8868\u73fe\u3092\u5f97\u308b\u3053\u3068\u306f, \u6700\u3082\u57fa\u790e\u7684\u306a\u51e6\u7406\u306e\u4e00\u3064\u3067\u3059.\nLLM\u306e\u6642\u4ee3\u306b\u304a\u3044\u3066, BERT\u306a\u3069\u306e\u4e8b\u524d\u8a13\u7df4\u6e08\u307fTransformer\u30e2\u30c7\u30eb\u3084, Open AI API\u306b\u3088\u308bEmbeddings\u306f,\n\u30c6\u30ad\u30b9\u30c8\u5206\u6563\u8868\u73fe\u6280\u8853\u306b\u304a\u3044\u3066\u6700\u3082\u91cd\u8981\u306a\u6280\u8853\u3067\u3042\u308b\u3053\u3068\u306f\u3044\u3046\u307e\u3067\u3082\u306a\u304f, \u307e\u305f, \u7c21\u5358\u306b\u5b9f\u88c5\u3067\u304d\u308b\u3068\u3044\u3048\u3070\u5b9f\u88c5\u3067\u304d\u307e\u3059. \n\n\u3057\u304b\u3057, \u5b9f\u7528\u306e\u73fe\u5834\u306b\u304a\u3044\u3066, BERT\u3084, OpenAI API\u306a\u3069\u306e, \n\u9ad8\u4fa1\u306aGPU\u304c\u5fc5\u8981\u306a\u624b\u6cd5\u3084, 1 Query\u3054\u3068\u306b\u8cbb\u7528\u304c\u767a\u751f\u3059\u308bAPI\u3092\u7528\u3044\u305f\u6700\u5148\u7aef\u306e\u624b\u6cd5\u3092\u4f7f\u3046\u3053\u3068\u306f, \u8a08\u7b97\u91cf\u30fb\u904b\u7528\u30b3\u30b9\u30c8\u306e\u4e21\u9762\u304b\u3089\u8ca0\u8377\u304c\u8efd\u3044\u3068\u306f\u3044\u3048\u307e\u305b\u3093.\n\u307e\u305f, \u30c7\u30fc\u30bf\u30bb\u30c3\u30c8\u69cb\u7bc9\u6bb5\u968e\u306a\u3069\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u521d\u671f\u6bb5\u968e\u3067\u306e\u6982\u5ff5\u5b9f\u8a3c (PoC) \u306b\u304a\u3044\u3066, \n\u8f9e\u66f8\u30c7\u30fc\u30bf\u3084\u5f62\u614b\u7d20\u89e3\u6790\u5668\u306e~~\u3081\u3093\u3069\u304f\u3055\u3044~~\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u4f5c\u696d\u3084,\n\u305d\u308c\u305e\u308c\u3084\u3084\u7570\u306a\u308bAPI\u306e\u30e1\u30bd\u30c3\u30c9\u3084\u30d7\u30ed\u30d1\u30c6\u30a3\u3092\u8abf\u3079\u306a\u304c\u3089\u4f5c\u696d\u3092\u884c\u3046\u306e\u306f\u5c11\u3057\u3070\u304b\u308a\u624b\u9593\u3067\u3059.\n\n\u3053\u308c\u3089\u306e\u70b9\u3092\u8e0f\u307e\u3048\u3066, GPU\u304c\u3042\u308b\u3068\u306f\u9650\u3089\u306a\u3044\u624b\u5143\u74b0\u5883\u3067, \nPoC\u306b\u304a\u3051\u308b\u30e2\u30c7\u30ea\u30f3\u30b0\u30fb\u5206\u6790\u90e8\u5206\u3078\u901f\u3084\u304b\u306b\u6ce8\u529b\u3067\u304d\u3088\u3046\u306b,\nScikit-learn\u306e\u3088\u3046\u306b, \u6a5f\u80fd\u3054\u3068\u306b\u7d71\u4e00\u7684\u306aAPI\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3067, \n\u30c6\u30ad\u30b9\u30c8\u3092\u4e0e\u3048\u308c\u3070\u3068\u308a\u3042\u3048\u305a\u8272\u3005\u306a\u6587\u306e\u5206\u6563\u8868\u73fe\u3092\u53d6\u5f97\u3067\u304d\u308b\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u958b\u767a\u3057\u307e\u3057\u305f.\n\n#### Unmotivated development tasks (at this moment.)\n\n- Open-AI Embedding model\u3092\u4f7f\u3046\u3053\u3068. (\u9ad8\u3044.)\n- \u4e8b\u524d\u8a13\u7df4\u6e08\u307fTransformer\u30e2\u30c7\u30eb\u306b\u3088\u308bEmbedding\u306b\u3064\u3044\u3066, GPU\u304c\u5fc5\u8981\u306a\u30c1\u30e5\u30fc\u30cb\u30f3\u30b0\u6a5f\u80fd\u3092\u5b9f\u88c5\u3059\u308b\u3053\u3068. (\u624b\u5143\u306bGPU\u304c\u306a\u3044.)\n- \u5b9f\u884c\u901f\u5ea6\u306e\u305f\u3081\u306b\u30e9\u30a4\u30d6\u30e9\u30ea\u5185\u90e8\u306e\u53ef\u8aad\u6027\u3092\u5927\u304d\u304f\u4e0b\u3052\u308b\u3053\u3068. \n  - \u5c0f\u898f\u6a21\u306aPoC\u306b\u304a\u3044\u3066, \u30b3\u30fc\u30c9\u306e\u5b9f\u884c\u901f\u5ea6\u3088\u308a, \u5b9f\u88c5\u901f\u5ea6\u306e\u307b\u3046\u304c\u91cd\u8981\u3060\u3068\u8003\u3048\u3066\u3044\u307e\u3059.\n  - PoC\u5f8c\u306e\u5927\u898f\u6a21\u306a\u904b\u7528\u306b\u3066, \u901f\u5ea6\u3084\u30c7\u30a3\u30b9\u30af\u5bb9\u91cf\u304c\u554f\u984c\u306b\u306a\u3063\u305f\u5834\u5408\u304c\u3042\u308c\u3070, \n    \u672c\u30e9\u30a4\u30d6\u30e9\u30ea\u4e2d\u306e\u4e0d\u8981\u306a\u51e6\u7406\u3092\u305d\u308c\u305e\u308c\u306e\u958b\u767a\u8005\u304c\u524a\u9664\u3057\u305f\u308a\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u3057\u3084\u3059\u3044\u3088\u3046\u306b, \u53ef\u8aad\u6027\u3092\u7dad\u6301\u3057\u305f\u3044\u3067\u3059.\n\n\n#### Roadmap (motivated development tasks)\n\n- vectorizer inputs\u306edecode().\n- Google colab\u3067\u306e\u52d5\u4f5c\u74b0\u5883\u691c\u8a3c.\n\n### Coding rule\n\n<https://pep8-ja.readthedocs.io/ja/latest/>\n\n\n## License\n\n`sumire` is distributed under the terms of the MIT License. \n\n\n## Acknowledgements (Dependent libraries, data, and models.)\n\nSee `dependent_licenses.csv`.",
    "bugtrack_url": null,
    "license": "",
    "summary": "Scikit-learn compatible Japanese text vectorizer for CPU-based Japanese natural language processing.",
    "version": "1.0.2",
    "project_urls": {
        "Documentation": "https://reiven-c-t.github.io/sumire/",
        "Issues": "https://github.com/reiven-c-t/sumire/issues",
        "Source": "https://github.com/reiven-c-t/sumire"
    },
    "split_keywords": [
        "japanese",
        "nlp",
        "natural language processing",
        "scikit-learn",
        "tokenizer"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "65d7df6560c5c1250144978d1dc3615a600a50657ac027186f8758a1f30dfd14",
                "md5": "7c36f4645ed9e308a93445b8b03d79f2",
                "sha256": "d679fbc08104d603d8a8882e62119150eea6433f2980b3bf9b7184dd913c1224"
            },
            "downloads": -1,
            "filename": "sumire-1.0.2-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "7c36f4645ed9e308a93445b8b03d79f2",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.9",
            "size": 54298,
            "upload_time": "2024-01-31T14:38:02",
            "upload_time_iso_8601": "2024-01-31T14:38:02.210928Z",
            "url": "https://files.pythonhosted.org/packages/65/d7/df6560c5c1250144978d1dc3615a600a50657ac027186f8758a1f30dfd14/sumire-1.0.2-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "7973f6ac3c93d52d844388ffaf2827718b60edc550b00e1d4a613a60c26ac8bd",
                "md5": "b2797b32f682c78be7519b8272fe8af9",
                "sha256": "3e3f024534cf3d76f55f219805784e2c88906cb5125f10244b97e0d63b02846a"
            },
            "downloads": -1,
            "filename": "sumire-1.0.2.tar.gz",
            "has_sig": false,
            "md5_digest": "b2797b32f682c78be7519b8272fe8af9",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 24684,
            "upload_time": "2024-01-31T14:38:04",
            "upload_time_iso_8601": "2024-01-31T14:38:04.115375Z",
            "url": "https://files.pythonhosted.org/packages/79/73/f6ac3c93d52d844388ffaf2827718b60edc550b00e1d4a613a60c26ac8bd/sumire-1.0.2.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-01-31 14:38:04",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "reiven-c-t",
    "github_project": "sumire",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "sumire"
}
        
Elapsed time: 0.17312s