An open API service indexing awesome lists of open source software.

https://github.com/vaaaaanquish/dajare-python

駄洒落データを検索するコマンド、スクレイピングのためのツールキット
https://github.com/vaaaaanquish/dajare-python

Last synced: about 18 hours ago
JSON representation

駄洒落データを検索するコマンド、スクレイピングのためのツールキット

Awesome Lists containing this project

README

        

# dajare

皆さんに *幸* が訪れる駄洒落の *検索(Search)* を行うスクリプトと、駄洒落の *玄人* になりたい人向けにWebサイトからデータを *クロール* し駄洒落データベースを構築するためのスクリプトです。


## 利用方法

検索用の「dajare_search.py」と各ダジャレサイトのクローラとなる「dajare_crawler.py」を用意しています。

### 検索

ダジャレステーションの検索窓を利用して、ダジャレを検索します。

pypiからdajareコマンドを取得可能です。
```
$ pip install dajare
$ dajare 布団

布団がふっとんだ
今日、布団出たら恐怖飛んでた
猫、マントで寝込まんと?
...
```

### スクレイピング

Webサイト *で得た* *データ* をjsonにdumpします。

#### 環境構築

「pipenv」もしくは「自前で設定したpython環境」を利用する事ができます。
pipenvを用いる場合は`pipenv install`の実行のみでOKです。
pipenvを利用しない場合は、requirements.txtを利用して各moduleをinstallして下さい。
```
$ pipenv install
or
$ pip install -r requirements.txt
```

#### 実行

pipenvを利用する場合は以下のように実行します。
```
$ pipenv run python dajare_crawler.py --all
```


dajare_crawler.pyの引数は以下のようになっています。

| args | description | クロール先 |
| --- | --- | ---|
| -h, --help | help表示 | - |
| -a, --all | 全てのサイトのクロール | - |
| -b, --b | ダジャレナビ | https://dajarenavi.net |
| -c, --c | ダジャレステーション | https://dajare.jp |
| -d, --d | ダジャレネット | http://www.dajare.net |
| -e, --e | バカダス | http://www.biwa.ne.jp/~aki-ina/gyagu.html |
| -f, --f | ダジャレ辞典 | https://dajareshuu.web.fc2.com |
| -g, --g | 究極のダジャレ集 | http://syuukaizyo.fc2web.com/02.html |
| -i, --i | ダジャレの殿堂 | http://archives.kaishaseikatsu.jp |
| --output OUTPUT | 出力ディレクトリを指定 | - |
| --sleep SLEEP | requests毎のsleep (float) | - |


ダジャレネットとダジャレ辞典のデータをsampleディレクトリにsleep 3.0秒/requests で取得する時は以下のようになります。
```
$ python dajare_crawler.py -d -f --output ./sample --sleep 3.0
```


sleep値の設定等、スクレイピング時のルールについては、以下を参考にして下さい。
[Webスクレイピングする際のルールとPythonによる規約の読み込み - Stimulator](https://vaaaaaanquish.hatenablog.com/entry/2017/12/01/064227)


## 既存のデータ

2020/02/21時点でのダジャレ統計は以下の通りです。

| Webサイト | ダジャレ数 |
| --- | --- |
| ダジャレナビ | 48102 |
| ダジャレステーション | 64533 |
| ダジャレネット | 832 |
| バカダス | 1070 |
| ダジャレ辞典 | 1115 |
| 究極のダジャレ集 | 275 |
| ダジャレの殿堂 | 2200 |


## Json format

出力されるjsonは以下のようなフォーマットです。

```
{
"url": "https://dajare.jp/works/000/", # ダジャレが記載されているURL
"text": "布団が吹っ飛んだ", # ダジャレ
"author": "サンプル", # ダジャレ投稿者
"author_link": "/author/サンプル/", # ダジャレ投稿者へのLink
"mean_score": 5.0, # ダジャレ評価(平均)
"deviation_score": 30.0, # ダジャレ評価(偏差値)
"category": [ # ダジャレカテゴリのリスト
{
"link": "/category/1/",
"text": "動物"
},
{
"link": "/category/1/1/",
"text": "全般"
},
{
"link": "/category/1/1/1/",
"text": "全般"
}
],
"tag": [ # ダジャレに紐付いたキーワードのリスト
{
"link": "/keyword/布団/",
"text": "布団"
}
],
"eval_list": [ # 評価のリスト
{
"author": {
"link": "/author/テスト/",
"text": "テスト"
},
"score": 3.0,
"datetime": "2015/3/14 10:59"
},
]
}
```

取得できない場合は空テキストや0が入ります。このフォーマットは全てのクロール先サイトで共通です。


## 参考文献

### ダジャレ検出
- 谷津元樹, 荒木健治. "子音の音韻類似性及び SVM を用いた駄洒落検出手法." 知能と情報 28.5 (2016): 875-886. https://www.jstage.jst.go.jp/article/jsoft/28/5/28_875/_article/-char/ja/
- 谷津元樹, 荒木健治. "動画コメントデータ及びブログ記事における駄洒落の抽出." 情報処理学会第 81 回全国大会 6 (2019): 07. http://arakilab.media.eng.hokudai.ac.jp/~araki/2018/2018-D-11.pdf
- 文章からダジャレのみを抜き出すコマンドを作ってみた - Qiita https://qiita.com/kurehajime/items/a922d42dff5e0f03d32c
- おもしろいダジャレを入力すると布団が吹っ飛ぶ装置を作った - Qiita https://qiita.com/fujit33/items/dbfbd7a2aa3858067b6c
- ダジャレ TechTalk - エムスリーテックブログ https://www.m3tech.blog/entry/2018/08/03/182447
- ニコニココメントデータからの駄洒落検出 - 谷津元樹 青山学院大学 https://www.nii.ac.jp/dsc/idr/userforum/startup/IDR-UF2019_S03.pdf
- ダジャレを判定する - Stimulator https://vaaaaaanquish.hatenablog.com/entry/2020/12/11/122721

### ダジャレデータベース
- 荒木健治. "駄洒落データベースの構築及び分析" ことば工学研究会: 人工知能学会第 2 種研究会ことば工学研究会 57 (2018): 39-48. http://arakilab.media.eng.hokudai.ac.jp/~araki/2017/2017-C-3.pdf
- 荒木健治. "駄洒落データベースを用いた駄洒落生成システムの性能評価" ことば工学研究会: 人工知能学会第 2 種研究会ことば工学研究会 56 (2017): 13-24. https://ci.nii.ac.jp/naid/40021582065/
- 荒木健治. "駄洒落データベースの拡張及び分析" ことば工学研究会: 人工知能学会第 2 種研究会ことば工学研究会資料 58 (2018): 1-15. https://ci.nii.ac.jp/naid/40021829772/

### ダジャレ生成
- 内田ゆず, 荒木健治. "オノマトペに着目した駄洒落の面白さの分析―駄洒落の自動生成に向けて―." 日本知能情報ファジィ学 第35回ファジィシステムシンポジウム. 2019. https://www.jstage.jst.go.jp/article/fss/35/0/35_332/_article/-char/ja/
- 金久保正明. "形態素解析手法と通俗的単語群に基づく類音文変換システム." 情報処理学会論文誌 54.7 (2013): 1937-1950. https://ipsj.ixsq.nii.ac.jp/ej/?action=pages_view_main&active_action=repository_view_main_item_detail&item_id=94391&item_no=1&page_id=13&block_id=8
- 田辺 公一朗. "駄洒落のコンピュータによる処理-- 駄洒落生成システムの基本設計 --" Sanno University Bulletin Vol.26 No. 1 September 2005 https://www.sanno.ac.jp/undergraduate/library/cpir4n0000006hnm-att/260104.pdf
- 阿部香央莉, et al. "Zunkobot: 複数の知識モジュールを統合した雑談対話システム." SIG-SLUD 5.02 (2018): 112-117. https://jsai.ixsq.nii.ac.jp/ej/?action=repository_action_common_download&item_id=9639&item_no=1&attribute_id=1&file_no=1

### ダジャレ分析
- 内田ゆず, 荒木健治. "駄洒落に使用されるオノマトペの特徴分析." 知能と情報 32.1 (2020): 507-511. https://www.jstage.jst.go.jp/article/jsoft/32/1/32_507/_article/-char/ja/
- 谷津元樹, 荒木健治. "駄洒落の面白さにおける要因の分析." 日本知能情報ファジィ学会 講演論文集 第32回ファジィシステムシンポジウム. 2016. https://www.jstage.jst.go.jp/article/fss/32/0/32_237/_article/-char/ja/
- 川原繁人, 篠原和子. "ダジャレから見る母音の近似性." 音声研究 13.3 (2009): 101-110. https://ci.nii.ac.jp/naid/110008722613/
- 篠原和子, 川原繁人. "日本語のダジャレにおける音節挿入." 日本認知言語学会論文集 10 (2010): 313-323. https://ci.nii.ac.jp/naid/40018766044/
- KOBAYASHI Yoshitomo. "駄洒落の基本構造と笑い" 東京外国語大学 http://www.tufs.ac.jp/st/personal/03/conanweb/dajare.htm

### ダジャレ対話
- 徐云帆, 荒木健治. "雑談対話システムにおける LSTM を用いた駄洒落による対話破綻回避の有効性." SIG-SLUD 5.02 (2018): 143-148. https://jsai.ixsq.nii.ac.jp/ej/?action=repository_action_common_download&item_id=9645&item_no=1&attribute_id=1&file_no=1
- 谷津元樹. "統合型対話システムにおける話題適応及び駄洒落ユーモア処理に関する研究." (2017). https://eprints.lib.hokudai.ac.jp/dspace/bitstream/2115/65779/1/Motoki_Yatsu.pdf


## 開発
Pull Requestをお待ちしております。READMEにダジャレを生やすだけでもOKです。

開発者向けのツールキットもリポジトリ内に含んでいますので活用して下さい。

- クロールした結果のjsonの中身を見るためのjupyter nootbook
- https://github.com/vaaaaanquish/dajare-python/blob/master/ipynb/check_json.ipynb
- クロールの開発用jupyter notebook
- https://github.com/vaaaaanquish/dajare-python/blob/master/ipynb/scraping_dev.ipynb