Name | pyjpboatrace JSON |
Version |
0.3.1
JSON |
| download |
home_page | None |
Summary | PyJPBoatrace: Python-based Japanese boatrace tools |
upload_time | 2024-06-01 16:36:55 |
maintainer | None |
docs_url | None |
author | None |
requires_python | >=3.8 |
license | MIT License Copyright (c) 2020 hmasdev Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
keywords |
kyotei
boatrace
data analysis
|
VCS |
|
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
# PyJPBoatRace: Python-based Japanese boatrace tools :speedboat:
![GitHub top language](https://img.shields.io/github/languages/top/hmasdev/pyjpboatrace)
![GitHub tag (latest SemVer)](https://img.shields.io/github/v/tag/hmasdev/pyjpboatrace?sort=semver)
![GitHub](https://img.shields.io/github/license/hmasdev/pyjpboatrace)
![GitHub last commit](https://img.shields.io/github/last-commit/hmasdev/pyjpboatrace)
[![PyPI version](https://badge.fury.io/py/pyjpboatrace.svg)](https://pypi.org/project/pyjpboatrace/)
![Scheduled Test](https://github.com/hmasdev/pyjpboatrace/actions/workflows/tests_on_schedule.yaml/badge.svg)
Japanese boat race is extremely exciting sports.
It is also fun to predict the results of races.
Prediction like machine learning method requires data.
Thus, this package provides you with useful tools for data analysis and auto-betting for boatrace.
## Installation
### Requirements
If you want to deposit, withdraw and betting with pyjpboatrace,
one of the following browers is required at least:
- Chrome
- Firefox
- Edge
### Dependencies
- python >= 3.8
- requests>=2.28.1
- beautifulsoup4>=4.11.1
- selenium>=4.6
### User installation
```bash
pip install -U pyjpboatrace
```
## How to use
1. (optional) create an instance of UserInformation;
2. (optional) create a selenium driver;
3. create an instance of PyJPBoatrace;
4. execute scraping and operating.
NOTE: you must create a UserInformation instance and a selenium driver to order to deposit, withdraw or bet.
### UserInformation
- `pyjpboatrace.user_information.UserInformation(userid:str, pin:str, auth_pass:str, vote_pass:str, json_file:str)`
NOTE: If you use a json file to create an instance of UserInformation, the json file should contain the following keys: userid, pin, auth_pass and vote_pass.
### Selenium Driver
You can use the following functions to create selenium drivers:
- pyjpboatrace.drivers.create_chrome_driver()
- pyjpboatrace.drivers.create_firefox_driver()
- pyjpboatrace.drivers.create_edge_driver()
- pyjpboatrace.drivers.create_httpget_driver()
NOTE 1: you can use your own selenium driver.
NOTE 2: If you use create_httpget_driver, you cannot execute the following operations, deposit, withdraw or bet.
### Scraping and Operating
PyJPBoatrace provides 2 main functions: scraping and operating.
The former is scraping race information, odds and so on;
the latter is betting, depositing and withdrawing.
#### Scraping
- Get a list of stadiums which hold races on the given day:
- API:
- ```python
PyJPBoatrace().get_stadiums(d: datetime.date) -> Dict[str, Any]
```
- ```python
PyJPBoatrace().Stadiums.get(d: datetime.date) -> Dict[str, Any]
```
- Return:
<details>
<summary> Sample </summary>
```python
>>> from pyjpboatrace import PyJPBoatrace
>>> from datetime import date
>>> from pprint import pprint
>>> pprint(PyJPBoatrace().get_stadiums(date(2021, 8, 12)))
{'date': '2021-08-12',
'びわこ': {'day': '3日目',
'grade': ['ippan'],
'period': ['2021-08-10', '2021-08-15'],
'status': '-',
'timeframe': '',
'title': '滋賀県知事杯争奪第26回びわこカップ'},
'三国': {'day': '2日目',
'grade': ['ippan'],
'period': ['2021-08-11', '2021-08-16'],
'status': '-',
'timeframe': 'morning',
'title': '第49回しぶき賞'},
'下関': {'day': '最終日',
'grade': ['ippan'],
'period': ['2021-08-06', '2021-08-12'],
'status': '-',
'timeframe': 'nighter',
'title': 'Hayashikane杯'},
'唐津': {'day': '最終日',
'grade': ['ippan'],
'period': ['2021-08-07', '2021-08-12'],
'status': '-',
'timeframe': 'morning',
'title': '唐津大賞がばい王者決定戦'},
'多摩川': {'day': '最終日',
'grade': ['ippan'],
'period': ['2021-08-08', '2021-08-12'],
'status': '-',
'timeframe': 'summer',
'title': '第59回スポーツニッポン賞'},
'宮島': {'day': '最終日',
'grade': ['ippan'],
'period': ['2021-08-07', '2021-08-12'],
'status': '-',
'timeframe': '',
'title': '第51回スポーツニッポン杯'},
'尼崎': {'day': '4日目',
'grade': ['ippan'],
'period': ['2021-08-09', '2021-08-14'],
'status': '-',
'timeframe': '',
'title': '日本財団会長杯争奪第49回オール兵庫王座決定戦'},
'常滑': {'day': '2日目',
'grade': ['ippan'],
'period': ['2021-08-11', '2021-08-16'],
'status': '-',
'timeframe': '',
'title': '名鉄杯争奪2021納涼お盆レース'},
'平和島': {'day': '3日目',
'grade': ['ippan'],
'period': ['2021-08-10', '2021-08-15'],
'status': '-',
'timeframe': 'summer',
'title': '第61回デイリースポーツサマーカップ'},
'戸田': {'day': '初日',
'grade': ['ippan'],
'period': ['2021-08-12', '2021-08-17'],
'status': '-',
'timeframe': '',
'title': '第44回戸田ボート大賞・サンケイスポーツ杯'},
'桐生': {'day': '3日目',
'grade': ['ippan'],
'period': ['2021-08-10', '2021-08-15'],
'status': '-',
'timeframe': 'nighter',
'title': '第55回報知新聞社杯\u3000お盆レース'},
'若松': {'day': '4日目',
'grade': ['ippan'],
'period': ['2021-08-08', '2021-08-13'],
'status': '-',
'timeframe': 'nighter',
'title': '日刊スポーツ杯お盆特選競走'},
'蒲郡': {'day': '初日',
'grade': ['ippan'],
'period': ['2021-08-12', '2021-08-17'],
'status': '-',
'timeframe': 'nighter',
'title': '日刊スポーツ杯争奪\u3000納涼しぶきお盆特別選抜戦'},
'鳴門': {'day': '4日目',
'grade': ['ippan'],
'period': ['2021-08-09', '2021-08-14'],
'status': '-',
'timeframe': 'morning',
'title': '第54回渦王杯競走'}}
```
</details>
- To get 12 races held in the given stadium on the given day:
- API:
- ```python
PyJPBoatrace().get_12races(d: datetime.date, stadium: int) -> Dict[str, Any]
```
- ```python
PyJPBoatrace().Races.get(d: datetime.date, stadium: int) -> Dict[str, Any]
```
- Return:
<details>
<summary> Sample </summary>
```python
>>> from pyjpboatrace import PyJPBoatrace
>>> from datetime import date
>>> from pprint import pprint
>>> pprint(PyJPBoatrace().get_12races(date(2021, 8, 12), 1))
{'10R': {'racers': {'boat1': {'class': 'B1', 'name': '佐藤航'},
'boat2': {'class': 'A1', 'name': '大澤普司'},
'boat3': {'class': 'A2', 'name': '橋本久和'},
'boat4': {'class': 'A1', 'name': '江口晃生'},
'boat5': {'class': 'B1', 'name': '土屋太朗'},
'boat6': {'class': 'A2', 'name': '加瀬智宏'}},
'status': '発売終了',
'vote_limit': '2021-08-12 19:43:00'},
'11R': {'racers': {'boat1': {'class': 'A2', 'name': '藤生雄人'},
'boat2': {'class': 'A1', 'name': '毒島誠'},
'boat3': {'class': 'A2', 'name': '長谷川充'},
'boat4': {'class': 'A1', 'name': '上村純一'},
'boat5': {'class': 'B1', 'name': '津久井拓也'},
'boat6': {'class': 'B1', 'name': '松本純平'}},
'status': '発売終了',
'vote_limit': '2021-08-12 20:14:00'},
'12R': {'racers': {'boat1': {'class': 'A1', 'name': '久田敏之'},
'boat2': {'class': 'A1', 'name': '金子拓矢'},
'boat3': {'class': 'A2', 'name': '木村浩士'},
'boat4': {'class': 'A1', 'name': '椎名豊'},
'boat5': {'class': 'A2', 'name': '本橋克洋'},
'boat6': {'class': 'A2', 'name': '野村誠'}},
'status': '発売終了',
'vote_limit': '2021-08-12 20:45:00'},
'1R': {'racers': {'boat1': {'class': 'B1', 'name': '渡辺史之'},
'boat2': {'class': 'B1', 'name': '島倉都'},
'boat3': {'class': 'A2', 'name': '鳥居塚孝博'},
'boat4': {'class': 'B1', 'name': '松本純平'},
'boat5': {'class': 'A2', 'name': '橋本久和'},
'boat6': {'class': 'B2', 'name': '宮崎安奈'}},
'status': '発売終了',
'vote_limit': '2021-08-12 15:22:00'},
'2R': {'racers': {'boat1': {'class': 'B1', 'name': '佐口達也'},
'boat2': {'class': 'A2', 'name': '本橋克洋'},
'boat3': {'class': 'B1', 'name': '寺本昇平'},
'boat4': {'class': 'B1', 'name': '津久井拓也'},
'boat5': {'class': 'B1', 'name': '久保原秀人'},
'boat6': {'class': 'A2', 'name': '中里英夫'}},
'status': '発売終了',
'vote_limit': '2021-08-12 15:49:00'},
'3R': {'racers': {'boat1': {'class': 'B1', 'name': '小川時光'},
'boat2': {'class': 'A2', 'name': '野村誠'},
'boat3': {'class': 'B2', 'name': '黄金井裕子'},
'boat4': {'class': 'A2', 'name': '藤生雄人'},
'boat5': {'class': 'B1', 'name': '高山秀雄'},
'boat6': {'class': 'A1', 'name': '関浩哉'}},
'status': '発売終了',
'vote_limit': '2021-08-12 16:16:00'},
'4R': {'racers': {'boat1': {'class': 'B1', 'name': '栗原謙治'},
'boat2': {'class': 'A2', 'name': '金子賢志'},
'boat3': {'class': 'B1', 'name': '関根彰人'},
'boat4': {'class': 'A1', 'name': '金子拓矢'},
'boat5': {'class': 'B2', 'name': '大久保佑香'},
'boat6': {'class': 'B1', 'name': '土屋太朗'}},
'status': '発売終了',
'vote_limit': '2021-08-12 16:45:00'},
'5R': {'racers': {'boat1': {'class': 'B1', 'name': '原加央理'},
'boat2': {'class': 'B1', 'name': '佐藤航'},
'boat3': {'class': 'B1', 'name': '蜂須瑞生'},
'boat4': {'class': 'A2', 'name': '一柳和孝'},
'boat5': {'class': 'B1', 'name': '外崎悟'},
'boat6': {'class': 'A1', 'name': '毒島誠'}},
'status': '発売終了',
'vote_limit': '2021-08-12 17:13:00'},
'6R': {'racers': {'boat1': {'class': 'A1', 'name': '椎名豊'},
'boat2': {'class': 'B1', 'name': '久保田美紀'},
'boat3': {'class': 'B1', 'name': '太田克哉'},
'boat4': {'class': 'B1', 'name': '島倉都'},
'boat5': {'class': 'B1', 'name': '金澤一洋'},
'boat6': {'class': 'B1', 'name': '寺本昇平'}},
'status': '発売終了',
'vote_limit': '2021-08-12 17:42:00'},
'7R': {'racers': {'boat1': {'class': 'A2', 'name': '木村浩士'},
'boat2': {'class': 'B1', 'name': '久保原秀人'},
'boat3': {'class': 'A1', 'name': '上村純一'},
'boat4': {'class': 'B1', 'name': '鹿島敏弘'},
'boat5': {'class': 'B2', 'name': '宮崎安奈'},
'boat6': {'class': 'B2', 'name': '黄金井裕子'}},
'status': '発売終了',
'vote_limit': '2021-08-12 18:11:00'},
'8R': {'racers': {'boat1': {'class': 'A2', 'name': '鳥居塚孝博'},
'boat2': {'class': 'B1', 'name': '高山秀雄'},
'boat3': {'class': 'B1', 'name': '吉田稔'},
'boat4': {'class': 'B1', 'name': '田中定雄'},
'boat5': {'class': 'A1', 'name': '久田敏之'},
'boat6': {'class': 'B2', 'name': '大久保佑香'}},
'status': '発売終了',
'vote_limit': '2021-08-12 18:41:00'},
'9R': {'racers': {'boat1': {'class': 'B1', 'name': '崎利仁'},
'boat2': {'class': 'A2', 'name': '中里英夫'},
'boat3': {'class': 'B1', 'name': '塚原武之'},
'boat4': {'class': 'A1', 'name': '土屋智則'},
'boat5': {'class': 'B1', 'name': '関根彰人'},
'boat6': {'class': 'A1', 'name': '山崎智也'}},
'status': '発売終了',
'vote_limit': '2021-08-12 19:12:00'},
'date': '2021-08-12',
'stadium': 1}
```
</details>
- To get the basic information of the race in the stadium on a day:
- API:
- ```python
PyJPBoatrace().get_race_info(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- ```python
PyJPBoatrace().RaceInfo.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- Return:
<details>
<summary> Sample </summary>
```python
>>> from pyjpboatrace import PyJPBoatrace
>>> from datetime import date
>>> from pprint import pprint
>>> pprint(PyJPBoatrace().get_race_info(date(2021, 8, 12), 10, 1))
{'boat1': {'F': 0,
'L': 0,
'age': 47,
'aveST': 0.16,
'birthplace': '福井',
'boat': 13,
'boat_in2nd': 41.79,
'boat_in3rd': 58.21,
'branch': '福井',
'class': 'A1',
'global_in2nd': 40.45,
'global_in3rd': 53.93,
'global_win_pt': 5.73,
'local_in2nd': 52.38,
'local_in3rd': 67.46,
'local_win_pt': 6.94,
'motor': 44,
'motor_in2nd': 53.42,
'motor_in3rd': 63.01,
'name': '武田光史',
'racerid': 3654,
'result': [{'ST': 0.19,
'boat': 5,
'course': 5,
'race': 6,
'rank': 4},
{'ST': 0.14,
'boat': 3,
'course': 3,
'race': 12,
'rank': 5},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{}],
'weight': 52.6},
'boat2': {'F': 0,
'L': 0,
'age': 25,
'aveST': 0.21,
'birthplace': '愛知',
'boat': 64,
'boat_in2nd': 22.67,
'boat_in3rd': 36.0,
'branch': '愛知',
'class': 'B1',
'global_in2nd': 10.17,
'global_in3rd': 20.34,
'global_win_pt': 3.18,
'local_in2nd': 3.33,
'local_in3rd': 3.33,
'local_win_pt': 2.0,
'motor': 24,
'motor_in2nd': 42.67,
'motor_in3rd': 68.0,
'name': '大澤誠也',
'racerid': 5074,
'result': [{'ST': 0.19,
'boat': 3,
'course': 3,
'race': 6,
'rank': 3},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{}],
'weight': 53.1},
'boat3': {'F': 0,
'L': 0,
'age': 45,
'aveST': 0.17,
'birthplace': '愛知',
'boat': 41,
'boat_in2nd': 29.33,
'boat_in3rd': 52.0,
'branch': '愛知',
'class': 'B1',
'global_in2nd': 29.79,
'global_in3rd': 54.26,
'global_win_pt': 5.39,
'local_in2nd': 31.48,
'local_in3rd': 51.85,
'local_win_pt': 5.09,
'motor': 51,
'motor_in2nd': 49.32,
'motor_in3rd': 63.01,
'name': '堀本裕也',
'racerid': 3895,
'result': [{'ST': 0.06,
'boat': 5,
'course': 5,
'race': 4,
'rank': 5},
{'ST': 0.2,
'boat': 2,
'course': 2,
'race': 11,
'rank': 4},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{}],
'weight': 50.0},
'boat4': {'F': 0,
'L': 0,
'age': 47,
'aveST': 0.18,
'birthplace': '石川',
'boat': 36,
'boat_in2nd': 32.43,
'boat_in3rd': 44.59,
'branch': '福井',
'class': 'B1',
'global_in2nd': 17.17,
'global_in3rd': 29.29,
'global_win_pt': 3.99,
'local_in2nd': 21.59,
'local_in3rd': 35.23,
'local_win_pt': 4.45,
'motor': 41,
'motor_in2nd': 45.95,
'motor_in3rd': 64.86,
'name': '信濃由行',
'racerid': 3620,
'result': [{'ST': 0.26,
'boat': 5,
'course': 3,
'race': 3,
'rank': 5},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{}],
'weight': 52.3},
'boat5': {'F': 0,
'L': 0,
'age': 30,
'aveST': 0.19,
'birthplace': '石川',
'boat': 17,
'boat_in2nd': 21.79,
'boat_in3rd': 46.15,
'branch': '福井',
'class': 'B1',
'global_in2nd': 37.5,
'global_in3rd': 56.73,
'global_win_pt': 5.56,
'local_in2nd': 35.04,
'local_in3rd': 52.55,
'local_win_pt': 5.53,
'motor': 61,
'motor_in2nd': 43.28,
'motor_in3rd': 64.18,
'name': '木田峰由季',
'racerid': 4587,
'result': [{'ST': 0.19,
'boat': 2,
'course': 2,
'race': 3,
'rank': 3},
{'ST': 0.21,
'boat': 4,
'course': 5,
'race': 10,
'rank': 2},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{}],
'weight': 52.2},
'boat6': {'F': 0,
'L': 0,
'age': 21,
'aveST': '-',
'birthplace': '福井',
'boat': 15,
'boat_in2nd': 26.76,
'boat_in3rd': 39.44,
'branch': '福井',
'class': 'B2',
'global_in2nd': 0.0,
'global_in3rd': 0.0,
'global_win_pt': 1.29,
'local_in2nd': 0.0,
'local_in3rd': 0.0,
'local_win_pt': 1.0,
'motor': 54,
'motor_in2nd': 43.84,
'motor_in3rd': 63.01,
'name': '加藤優弥',
'racerid': 5185,
'result': [{'ST': 0.01,
'boat': 6,
'course': 6,
'race': 4,
'rank': 6},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{},
{}],
'weight': 52.6},
'date': '2021-08-12',
'race': 1,
'race_title': ['みくにあさイチ', '1800m'],
'stadium': 10}
```
</details>
- To get the odds of win (単勝) and place-show (複勝) of the race in the stadium on the day:
- API:
- ```python
PyJPBoatrace().get_odds_win_placeshow(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- ```python
PyJPBoatrace().WinPlaceshowOdds.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- Return:
<details>
<summary> Sample </summary>
```python
>>> from pyjpboatrace import PyJPBoatrace
>>> from datetime import date
>>> from pprint import pprint
>>> pprint(PyJPBoatrace().get_odds_win_placeshow(date(2021, 8, 12), 10, 1))
{'date': '2021-08-12',
'place_show': {'1': [1.0, 1.0],
'2': [2.5, 7.0],
'3': [2.0, 5.5],
'4': [2.3, 6.4],
'5': [1.5, 4.0],
'6': [3.8, 10.6]},
'race': 1,
'stadium': 10,
'update': '締切時オッズ',
'win': {'1': 1.0, '2': 20.7, '3': 11.0, '4': 18.4, '5': 23.6, '6': 27.6}}
```
</details>
- To get the odds of quinella place (拡連複) of the race in the stadioum on the day:
- API:
- ```python
PyJPBoatrace().get_odds_quinellaplace(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- ```python
PyJPBoatrace().QuinellaplaceOdds.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- Return:
<details>
<summary> Sample </summary>
```python
>>> from pyjpboatrace import PyJPBoatrace
>>> from datetime import date
>>> from pprint import pprint
>>> pprint(PyJPBoatrace().get_odds_quinellaplace(date(2021, 8, 12), 10, 1))
{'1=2': [1.6, 2.1],
'1=3': [1.1, 1.4],
'1=4': [3.7, 5.0],
'1=5': [1.1, 1.4],
'1=6': [18.1, 23.4],
'2=3': [6.1, 9.9],
'2=4': [10.6, 13.0],
'2=5': [4.1, 6.4],
'2=6': [30.1, 34.8],
'3=4': [5.1, 7.1],
'3=5': [1.9, 3.4],
'3=6': [16.9, 22.4],
'4=5': [6.4, 8.9],
'4=6': [50.0, 51.9],
'5=6': [16.0, 20.9],
'date': '2021-08-12',
'race': 1,
'stadium': 10,
'update': '締切時オッズ'}
```
</details>
- To get the odds of exacta (二連単) and quinella (二連複) of the race in the stadioum on the day:
- API:
- ```python
PyJPBoatrace().get_odds_exacta_quinella(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- ```python
PyJPBoatrace().ExactaQuinellaOdds.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- Return:
<details>
<summary> Sample </summary>
```python
>>> from pyjpboatrace import PyJPBoatrace
>>> from datetime import date
>>> from pprint import pprint
>>> pprint(PyJPBoatrace().get_odds_exacta_quinella(date(2021, 8, 12), 10, 1))
{'date': '2021-08-12',
'exacta': {'1-2': 4.8,
'1-3': 2.6,
'1-4': 7.2,
'1-5': 4.0,
'1-6': 63.9,
'2-1': 26.4,
'2-3': 75.9,
'2-4': 291.8,
'2-5': 132.6,
'2-6': 810.5,
'3-1': 15.9,
'3-2': 94.7,
'3-4': 110.5,
'3-5': 41.2,
'3-6': 429.1,
'4-1': 66.9,
'4-2': 260.5,
'4-3': 187.0,
'4-5': 105.7,
'4-6': 455.9,
'5-1': 13.5,
'5-2': 74.4,
'5-3': 47.9,
'5-4': 70.8,
'5-6': 97.2,
'6-1': 347.3,
'6-2': 663.2,
'6-3': 729.5,
'6-4': 729.5,
'6-5': 455.9},
'quinella': {'1=2': 4.8,
'1=3': 1.8,
'1=4': 6.1,
'1=5': 4.4,
'1=6': 73.8,
'2=3': 79.5,
'2=4': 94.0,
'2=5': 36.9,
'2=6': 172.3,
'3=4': 64.6,
'3=5': 16.6,
'3=6': 206.8,
'4=5': 33.3,
'4=6': 172.3,
'5=6': 129.2},
'race': 1,
'stadium': 10,
'update': '締切時オッズ'}
```
</details>
- To get the odds of trifecta (三連単) of the race in the stadioum on the day:
- API:
- ```python
PyJPBoatrace().get_odds_trifecta(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- ```python
PyJPBaotrace().TrifectaOdds.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- Return:
<details>
<summary> Sample </summary>
```python
>>> from pyjpboatrace import PyJPBoatrace
>>> from datetime import date
>>> from pprint import pprint
>>> pprint(PyJPBoatrace().get_odds_trifecta(date(2021, 8, 12), 10, 1))
{'1-2-3': 12.1,
'1-2-4': 22.8,
'1-2-5': 10.7,
'1-2-6': 136.2,
'1-3-2': 11.2,
'1-3-4': 9.5,
'1-3-5': 5.2,
'1-3-6': 101.2,
'1-4-2': 33.9,
'1-4-3': 19.2,
'1-4-5': 18.8,
'1-4-6': 169.1,
'1-5-2': 11.9,
'1-5-3': 7.3,
'1-5-4': 16.0,
'1-5-6': 81.5,
'1-6-2': 400.4,
'1-6-3': 357.7,
'1-6-4': 399.1,
'1-6-5': 297.0,
'2-1-3': 143.1,
'2-1-4': 251.5,
'2-1-5': 135.8,
'2-1-6': 759.3,
'2-3-1': 274.6,
'2-3-4': 926.4,
'2-3-5': 574.7,
'2-3-6': 1866.0,
'2-4-1': 715.5,
'2-4-3': 1247.0,
'2-4-5': 981.4,
'2-4-6': 2853.0,
'2-5-1': 256.5,
'2-5-3': 542.1,
'2-5-4': 838.8,
'2-5-6': 1306.0,
'2-6-1': 2789.0,
'2-6-3': 3103.0,
'2-6-4': 4138.0,
'2-6-5': 2342.0,
'3-1-2': 81.8,
'3-1-4': 69.4,
'3-1-5': 35.9,
'3-1-6': 403.0,
'3-2-1': 238.0,
'3-2-4': 709.4,
'3-2-5': 432.5,
'3-2-6': 1469.0,
'3-4-1': 206.0,
'3-4-2': 684.0,
'3-4-5': 226.7,
'3-4-6': 1591.0,
'3-5-1': 82.6,
'3-5-2': 282.4,
'3-5-4': 221.2,
'3-5-6': 775.9,
'3-6-1': 1970.0,
'3-6-2': 2364.0,
'3-6-4': 3027.0,
'3-6-5': 2387.0,
'4-1-2': 330.1,
'4-1-3': 207.7,
'4-1-5': 179.9,
'4-1-6': 989.2,
'4-2-1': 780.8,
'4-2-3': 1452.0,
'4-2-5': 977.5,
'4-2-6': 2789.0,
'4-3-1': 477.4,
'4-3-2': 1286.0,
'4-3-5': 556.7,
'4-3-6': 2586.0,
'4-5-1': 259.4,
'4-5-2': 598.3,
'4-5-3': 399.1,
'4-5-6': 1030.0,
'4-6-1': 2728.0,
'4-6-2': 3310.0,
'4-6-3': 3762.0,
'4-6-5': 3267.0,
'5-1-2': 67.2,
'5-1-3': 46.4,
'5-1-4': 103.0,
'5-1-6': 287.0,
'5-2-1': 197.0,
'5-2-3': 420.8,
'5-2-4': 656.8,
'5-2-6': 1205.0,
'5-3-1': 100.8,
'5-3-2': 324.9,
'5-3-4': 332.8,
'5-3-6': 1149.0,
'5-4-1': 258.3,
'5-4-2': 625.4,
'5-4-3': 414.5,
'5-4-6': 1286.0,
'5-6-1': 800.9,
'5-6-2': 1205.0,
'5-6-3': 1279.0,
'5-6-4': 1724.0,
'6-1-2': 2320.0,
'6-1-3': 2257.0,
'6-1-4': 2921.0,
'6-1-5': 1786.0,
'6-2-1': 4070.0,
'6-2-3': 4514.0,
'6-2-4': 5643.0,
'6-2-5': 2921.0,
'6-3-1': 3598.0,
'6-3-2': 4774.0,
'6-3-4': 4433.0,
'6-3-5': 2387.0,
'6-4-1': 4514.0,
'6-4-2': 6534.0,
'6-4-3': 4138.0,
'6-4-5': 4004.0,
'6-5-1': 2559.0,
'6-5-2': 2698.0,
'6-5-3': 4070.0,
'6-5-4': 4774.0,
'date': '2021-08-12',
'race': 1,
'stadium': 10,
'update': '締切時オッズ'}
```
</details>
- To get the oods of trio (三連複) of the race in the stadioum on the day:
- API:
- ```python
PyJPBoatrace().get_odds_trio(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- ```python
PyJPBoatrace().Trio.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- Return:
<details>
<summary> Sample </summary>
```python
>>> from pyjpboatrace import PyJPBoatrace
>>> from datetime import date
>>> from pprint import pprint
>>> pprint(PyJPBoatrace().get_odds_trio(date(2021, 8, 12), 10, 1))
{'1=2=3': 5.1,
'1=2=4': 14.6,
'1=2=5': 4.7,
'1=2=6': 73.8,
'1=3=4': 5.9,
'1=3=5': 2.5,
'1=3=6': 73.8,
'1=4=5': 6.4,
'1=4=6': 106.6,
'1=5=6': 59.0,
'2=3=4': 98.4,
'2=3=5': 36.2,
'2=3=6': 295.3,
'2=4=5': 93.6,
'2=4=6': 426.5,
'2=5=6': 159.9,
'3=4=5': 45.7,
'3=4=6': 548.4,
'3=5=6': 191.9,
'4=5=6': 213.2,
'date': '2021-08-12',
'race': 1,
'stadium': 10,
'update': '締切時オッズ'}
```
</details>
- To get the just-before information, e.g. weather and start-timing, of the race in the stadioum on the day:
- API:
- ```python
PyJPBoatrace().get_just_before_info(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- ```python
PyJPBoatrace().JustBeforeInfo.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- Return:
<details>
<summary> Sample </summary>
```python
>>> from pyjpboatrace import PyJPBoatrace
>>> from datetime import date
>>> from pprint import pprint
>>> pprint(PyJPBoatrace().get_just_before_info(date(2021, 8, 12), 10, 1))
{'boat1': {'display_time': 6.77,
'name': '武田光史',
'parts_exchange': [],
'previous_race': {},
'propeller': '',
'tilt': -0.5,
'weight': 52.6,
'weight_adjustment': 0.0},
'boat2': {'display_time': 6.76,
'name': '大澤誠也',
'parts_exchange': [],
'previous_race': {},
'propeller': '',
'tilt': -0.5,
'weight': 53.1,
'weight_adjustment': 0.0},
'boat3': {'display_time': 6.77,
'name': '堀本裕也',
'parts_exchange': [],
'previous_race': {},
'propeller': '',
'tilt': -0.5,
'weight': 50.0,
'weight_adjustment': 2.0},
'boat4': {'display_time': 6.77,
'name': '信濃由行',
'parts_exchange': [],
'previous_race': {},
'propeller': '',
'tilt': -0.5,
'weight': 52.3,
'weight_adjustment': 0.0},
'boat5': {'display_time': 6.79,
'name': '木田峰由季',
'parts_exchange': [],
'previous_race': {},
'propeller': '',
'tilt': -0.5,
'weight': 52.2,
'weight_adjustment': 0.0},
'boat6': {'display_time': 6.81,
'name': '加藤優弥',
'parts_exchange': [],
'previous_race': {},
'propeller': '',
'tilt': -0.5,
'weight': 52.6,
'weight_adjustment': 0.0},
'date': '2021-08-12',
'race': 1,
'stadium': 10,
'start_display': {'course1': {'ST': 0.11, 'boat': 1},
'course2': {'ST': 0.13, 'boat': 2},
'course3': {'ST': 0.22, 'boat': 3},
'course4': {'ST': 0.17, 'boat': 4},
'course5': {'ST': 0.11, 'boat': 5},
'course6': {'ST': 0.13, 'boat': 6}},
'weather_information': {'direction': 14,
'temperature': 25.0,
'time': '14:53現在',
'water_temperature': 27.0,
'wave_height': 1.0,
'weather': '曇り',
'wind_direction': 2,
'wind_speed': 1.0}}
```
</details>
- To get the race result of the race in the stadioum on the day:
- API:
- ```python
PyJPBoatrace().get_race_result(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- ```python
PyJPBoatrace().Result.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]
```
- Return:
<details>
<summary> Sample </summary>
```python
>>> from pyjpboatrace import PyJPBoatrace
>>> from datetime import date
>>> from pprint import pprint
>>> pprint(PyJPBoatrace().get_race_result(date(2021, 8, 12), 10, 1))
{'date': '2021-08-12',
'kimarite': '逃げ',
'note': [],
'payoff': {'exacta': {'payoff': 400, 'popularity': 2, 'result': '1-5'},
'exacta_all': [{'payoff': 400, 'popularity': 2, 'result': '1-5'}],
'place_show': [{'payoff': 100, 'popularity': '', 'result': '1'},
{'payoff': 150, 'popularity': '', 'result': '5'}],
'place_show_all': [{'payoff': 100, 'popularity': '', 'result': '1'},
{'payoff': 150,
'popularity': '',
'result': '5'}],
'quinella': {'payoff': 440, 'popularity': 2, 'result': '1=5'},
'quinella_all': [{'payoff': 440, 'popularity': 2, 'result': '1=5'}],
'quinella_place': [{'payoff': 110,
'popularity': 2,
'result': '1=5'},
{'payoff': 110,
'popularity': 1,
'result': '1=3'},
{'payoff': 190,
'popularity': 4,
'result': '3=5'}],
'quinella_place_all': [{'payoff': 110,
'popularity': 2,
'result': '1=5'},
{'payoff': 110,
'popularity': 1,
'result': '1=3'},
{'payoff': 190,
'popularity': 4,
'result': '3=5'}],
'trifecta': {'payoff': 730, 'popularity': 2, 'result': '1-5-3'},
'trifecta_all': [{'payoff': 730,
'popularity': 2,
'result': '1-5-3'}],
'trio': {'payoff': 250, 'popularity': 1, 'result': '1=3=5'},
'trio_all': [{'payoff': 250, 'popularity': 1, 'result': '1=3=5'}],
'win': {'payoff': 100, 'popularity': '', 'result': '1'},
'win_all': [{'payoff': 100, 'popularity': '', 'result': '1'}]},
'race': 1,
'result': [{'boat': 1,
'name': '武田光史',
'racerid': 3654,
'rank': 1,
'time': '1\'49"2'},
{'boat': 5,
'name': '木田峰由季',
'racerid': 4587,
'rank': 2,
'time': '1\'50"8'},
{'boat': 3,
'name': '堀本裕也',
'racerid': 3895,
'rank': 3,
'time': '1\'52"6'},
{'boat': 2,
'name': '大澤誠也',
'racerid': 5074,
'rank': 4,
'time': '1\'54"1'},
{'boat': 6, 'name': '加藤優弥', 'racerid': 5185, 'rank': 5, 'time': ''},
{'boat': 4,
'name': '信濃由行',
'racerid': 3620,
'rank': 6,
'time': ''}],
'return': [],
'stadium': 10,
'start_information': {'course1': {'ST': 0.26, 'boat': 1},
'course2': {'ST': 0.25, 'boat': 2},
'course3': {'ST': 0.23, 'boat': 3},
'course4': {'ST': 0.25, 'boat': 4},
'course5': {'ST': 0.21, 'boat': 5},
'course6': {'ST': 0.17, 'boat': 6}},
'weather_information': {'direction': 14,
'temperature': 27.0,
'water_temperature': 26.0,
'wave_height': 1,
'weather': '曇り',
'wind_direction': 12,
'wind_speed': 1}}
```
</details>
- NOTE: you may be confused by the output of `PyJPBoatrace().get_race_result` because the contents of "payoff" key in the output have the following keys:
- "exacta"
- "exacta_all"
- "place_show"
- "place_show_all"
- "quinella"
- "quinella_all"
- "quinella_place"
- "quinella_place_all"
- "trifecta"
- "trifecta_all"
- "trio"
- "trio_all"
- "win"
- "win_all"
For "win", "exacta", "quinella", "trifecta" and "trio", the difference between a key without "all" footer and a key with "all" footer is that the former means ONE result while the latter means ALL results.
For example, if "1-2-3" and "1-2-4" is hit as trifecta in a race, that is, if 3rd boat and 4th boat are tied for third place, the valud of "trifecta" key is `{'payoff': ..., 'popularity': ..., 'result': '1-2-3'}` while the value of "trifecta_all" key is `[{'payoff': ..., 'popularity': ..., 'result': '1-2-3'}, {'payoff': ..., 'popularity': ..., 'result': '1-2-4'}]`.
On the other hand, for "place_show" and "quinella_place", there is no difference between a key without "all" footer and a key with "all" footer.
These functions return `dict` object.
#### Operations
- To deposit money for betting (Unit: 1,000 yen):
- API
- `PyJPBoatrace().deposit(num_of_thousands_yen: int) -> None`
- `PyJPBoatrace().Deposit.do(num_of_thousands_yen: int) -> None`
- Return:
- Nothing
- To get the limit of betting amount, that is, your current deposit:
- API
- `PyJPBoatrace().get_bet_limit() -> int`
- `PyJPBoatrace().BettingLimitCheck.do() -> int`
- Return:
- `int`: the amount of deposit
- To withdraw your current deposit:
- API:
- `PyJPBoatrace().withdraw() -> None`
- `PyJPBoatrace().Widthdraw.do() -> None`
- Return:
- Nothing
- To bet some tickets.
- API:
- ```python
PyJPBoatrace().bet(
stadium:int,
race:int,
trifecta_betting_dict: Dict[str, int],
trio_betting_dict: Dict[str, int],
exacta_betting_dict: Dict[str, int],
quinela_betting_dict: Dict[str, int],
quinellaplace_betting_dict: Dict[str, int],
win_betting_dict: Dict[str, int],
placeshow_betting_dict: Dict[str, int],
) -> bool
```
- ```python
PyJPBoatrace().Bet.do(
stadium:int,
race:int,
trifecta_betting_dict: Dict[str, int],
trio_betting_dict: Dict[str, int],
exacta_betting_dict: Dict[str, int],
quinela_betting_dict: Dict[str, int],
quinellaplace_betting_dict: Dict[str, int],
win_betting_dict: Dict[str, int],
placeshow_betting_dict: Dict[str, int],
) -> bool
```
- Each dictionary consits of pairs of winning numbers and betting amount, e.g., `{'1-2-3':100}` for trifecta_betting_dict
IMPORTANT NOTE: you must give a driver other than `HTTPGetDriver` to use above actions.
### Demo
#### Demo 1 : Getting odds data
The following example is useful.
Suppose that you want get the odds of trifecta of 4th race in stadium "桐生" on 2020/12/02 and dump the result into `data.json`.
```python
from datetime import date
import json
from pyjpboatrace import PyJPBoatrace
# initialize
boatrace_tools = PyJPBoatrace()
# get data
dic = boatrace_tools.get_odds_trifecta(d=date(2020,12,2), stadium=1, race=4)
# dump data
with open('data.json', 'w', encoding='utf-8') as f:
json.dump(dic, f, ensure_ascii=False)
# close (you can use 'with' statement)
boatrace_tools.close()
```
You can get many kinds of data as this example.
#### Demo 2 : Betting
Suppose it is 2020/12/02 and you want to bet 200 yen on trifecta 1-3-4 and 100 yen on trio 1=3=4 in the 2nd race in stadium "桐生" on 2020/12/02. NOTE: you need google chrome in the following example.
```python
from datetime import date
from pyjpboatrace import PyJPBoatrace
from pyjpboatrace.drivers import create_chrome_driver
from pyjpboatrace.const import STADIUMS_MAP
from pyjpboatrace.user_information import UserInformation
# initialize
user = UserInformation(
userid='YOUR_USER_ID',
pin='YOUR_PIN',
auth_pass='YOUR_AUTHENTIFICATION_PASSWORD',
vote_pass='YOUR_BETTING_PASSWORD',
)
boatrace_tools = PyJPBoatrace(
driver=create_chrome_driver(),
user_information=user
)
# deposit 1,000 yen
boatrace_tools.deposit(1)
# bet
stadium = {s:i for i,s in STADIUMS_MAP}.get("桐生")
race = 2
boatrace_tools.bet(
stadium=stadium,
race=race,
trifecta_betting_dict={'1-3-4':200},
trio_betting_dict={'1=3=4':100}
)
# waiting for the race result ...
# withdraw
boatrace_tools.withdraw()
# close (you can use 'with' statement)
boatrace_tools.close()
```
### NOTE
The map between integers and stadiums is given by `STADIUMS_MAP` in `pyjpboatrace.const`.
## Contribution Guide
### Requirement
- Python >= 3.8
- Chrome
- Firefox
- bash
- curl
### Issues
- For any bugs, use [BUG REPORT](https://github.com/hmasdev/pyjpboatrace/issues/new?assignees=&labels=bug&template=bug_report.md&title=%5BBUG%5D) to create an issue.
- For any enhancement, use [FEATURE REQUEST](https://github.com/hmasdev/pyjpboatrace/issues/new?assignees=&labels=enhancement&template=feature_request.md&title=) to create an issue.
- For other topics, create an issue with a clear and concise description.
### Pull Request
1. Fork ([https://github.com/hmasdev/pyjpboatrace/fork](https://github.com/hmasdev/pyjpboatrace/fork));
2. Create your feature branch (`git checkout -b feautre/xxxx`);
3. Test codes according to [Test Subsection](#HowToTestAnchor);
4. Commit your changes (`git commit -am 'Add xxxx feature`);
5. Push to the branch (`git push origin feature/xxxx`);
6. Create new Pull Request
### Setup the develop environment
First, fork this repository and clone it to your local machine.
```bash
git clone https://github.com/hmasdev/pyjpboatrace/
cd pyjpboatrace
```
Then, create a virtual environment for your development,
and install the required libraries.
```bash
python -m venv venv
source venv/bin/activate # for Linux or MacOS
# venv\Scripts\activate # for Windows
pip install -e .[dev]
```
<details>
<summary>[Deprecated] when using `pipenv`</summary>
```bash
pipenv sync --dev
```
</details>
### Test
<div id="HowToTestAnchor"></div>
You can do unit tests and integration tests as follows:
```bash
./download_html_for_test.sh # Only 1 time
pytest -m "not integrate and not spending_money" # unit tests
pytest # unit tests and integration tests
```
<details>
<summary>[Deprecated] when using `pipenv`</summary>
```bash
./download_html_for_test.sh # Only 1 time
pipenv run pytest -m "not integrate and not spending_money" # unit tests
pipenv run pytest # unit tests and integration tests
```
</details>
`pytest` does not test depositing, withdrawing or betting.
If you want to test them, make `.secrets.json` at first:
```json
{
"userid": "YOUR_USER_ID",
"pin": "YOUR_PIN",
"auth_pass": "YOUR_AUTHENTIFICATION_PASSWORD",
"vote_pass": "YOUR_BETTING_PASSWORD"
}
```
Then, run
```bash
pytest -m "spending_money"
```
<details>
<summary>[Deprecated] when using `pipenv`</summary>
```bash
pipenv run pytest -m "spending_money"
```
</details>
WARNING: Tests with `spending_money` spend 700 yen.
### Check the format of code and static types
You should execute the following codes to check the format of code and static types:
```bash
flake8 pyjpboatrace tests
mypy pyjpboatrace tests
```
<details>
<summary>[Deprecated] when using `pipenv`</summary>
```bash
pipenv run flake8 pyjpboatrace
pipenv run flake8 tests
pipenv run mypy pyjpboatrace
pipenv run mypy tests
```
</details>
### How to Update README.md
To update the content of [README.md](./README.md), please do not edit the file directly.
Instead, make your changes to [README.md.j2](./README.md.j2).
After making updates to `README.md.j2`, execute the following command to regenerate `README.md`:
```bash
python update_readme.py > README.md
```
This process is necessary because README.md is dynamically generated from the README.md.j2 template.
Direct modifications to README.md will be lost, as they are automatically overwritten by an automated process whenever the template is updated.
Remember, to preserve your changes, always update README.md.j2 and not README.md directly.
## LICENSE
[MIT](https://github.com/hmasdev/pyjpboatrace/tree/main/LICENSE)
## Authors
[hmasdev](https://github.com/hmasdev)
Raw data
{
"_id": null,
"home_page": null,
"name": "pyjpboatrace",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.8",
"maintainer_email": null,
"keywords": "kyotei, boatrace, data analysis",
"author": null,
"author_email": "hmasdev <hmasuidev1com@gmail.com>",
"download_url": "https://files.pythonhosted.org/packages/dd/47/bcc473c5f34af3409952c9381f7d597b13dbbb255d8829fb9816973badee/pyjpboatrace-0.3.1.tar.gz",
"platform": null,
"description": "# PyJPBoatRace: Python-based Japanese boatrace tools :speedboat:\n\n![GitHub top language](https://img.shields.io/github/languages/top/hmasdev/pyjpboatrace)\n![GitHub tag (latest SemVer)](https://img.shields.io/github/v/tag/hmasdev/pyjpboatrace?sort=semver)\n![GitHub](https://img.shields.io/github/license/hmasdev/pyjpboatrace)\n![GitHub last commit](https://img.shields.io/github/last-commit/hmasdev/pyjpboatrace)\n[![PyPI version](https://badge.fury.io/py/pyjpboatrace.svg)](https://pypi.org/project/pyjpboatrace/)\n![Scheduled Test](https://github.com/hmasdev/pyjpboatrace/actions/workflows/tests_on_schedule.yaml/badge.svg)\n\nJapanese boat race is extremely exciting sports.\nIt is also fun to predict the results of races.\nPrediction like machine learning method requires data.\nThus, this package provides you with useful tools for data analysis and auto-betting for boatrace.\n\n## Installation\n\n### Requirements\n\nIf you want to deposit, withdraw and betting with pyjpboatrace,\none of the following browers is required at least:\n\n- Chrome\n- Firefox\n- Edge\n\n### Dependencies\n\n- python >= 3.8\n- requests>=2.28.1\n- beautifulsoup4>=4.11.1\n- selenium>=4.6\n\n### User installation\n\n```bash\npip install -U pyjpboatrace\n```\n\n## How to use\n\n1. (optional) create an instance of UserInformation;\n2. (optional) create a selenium driver;\n3. create an instance of PyJPBoatrace;\n4. execute scraping and operating.\n\nNOTE: you must create a UserInformation instance and a selenium driver to order to deposit, withdraw or bet.\n\n### UserInformation\n\n- `pyjpboatrace.user_information.UserInformation(userid:str, pin:str, auth_pass:str, vote_pass:str, json_file:str)`\n\nNOTE: If you use a json file to create an instance of UserInformation, the json file should contain the following keys: userid, pin, auth_pass and vote_pass.\n\n### Selenium Driver\n\nYou can use the following functions to create selenium drivers:\n\n- pyjpboatrace.drivers.create_chrome_driver()\n- pyjpboatrace.drivers.create_firefox_driver()\n- pyjpboatrace.drivers.create_edge_driver()\n- pyjpboatrace.drivers.create_httpget_driver()\n\nNOTE 1: you can use your own selenium driver.\n\nNOTE 2: If you use create_httpget_driver, you cannot execute the following operations, deposit, withdraw or bet.\n\n### Scraping and Operating\n\nPyJPBoatrace provides 2 main functions: scraping and operating.\n\nThe former is scraping race information, odds and so on;\nthe latter is betting, depositing and withdrawing.\n\n#### Scraping\n\n- Get a list of stadiums which hold races on the given day:\n\n - API:\n\n - ```python\n PyJPBoatrace().get_stadiums(d: datetime.date) -> Dict[str, Any]\n ```\n\n - ```python\n PyJPBoatrace().Stadiums.get(d: datetime.date) -> Dict[str, Any]\n ```\n\n - Return:\n <details>\n <summary> Sample </summary>\n\n ```python\n >>> from pyjpboatrace import PyJPBoatrace\n >>> from datetime import date\n >>> from pprint import pprint\n >>> pprint(PyJPBoatrace().get_stadiums(date(2021, 8, 12)))\n {'date': '2021-08-12',\n '\u3073\u308f\u3053': {'day': '\uff13\u65e5\u76ee',\n 'grade': ['ippan'],\n 'period': ['2021-08-10', '2021-08-15'],\n 'status': '-',\n 'timeframe': '',\n 'title': '\u6ecb\u8cc0\u770c\u77e5\u4e8b\u676f\u4e89\u596a\u7b2c\uff12\uff16\u56de\u3073\u308f\u3053\u30ab\u30c3\u30d7'},\n '\u4e09\u56fd': {'day': '\uff12\u65e5\u76ee',\n 'grade': ['ippan'],\n 'period': ['2021-08-11', '2021-08-16'],\n 'status': '-',\n 'timeframe': 'morning',\n 'title': '\u7b2c\uff14\uff19\u56de\u3057\u3076\u304d\u8cde'},\n '\u4e0b\u95a2': {'day': '\u6700\u7d42\u65e5',\n 'grade': ['ippan'],\n 'period': ['2021-08-06', '2021-08-12'],\n 'status': '-',\n 'timeframe': 'nighter',\n 'title': '\uff28\uff41\uff59\uff41\uff53\uff48\uff49\uff4b\uff41\uff4e\uff45\u676f'},\n '\u5510\u6d25': {'day': '\u6700\u7d42\u65e5',\n 'grade': ['ippan'],\n 'period': ['2021-08-07', '2021-08-12'],\n 'status': '-',\n 'timeframe': 'morning',\n 'title': '\u5510\u6d25\u5927\u8cde\u304c\u3070\u3044\u738b\u8005\u6c7a\u5b9a\u6226'},\n '\u591a\u6469\u5ddd': {'day': '\u6700\u7d42\u65e5',\n 'grade': ['ippan'],\n 'period': ['2021-08-08', '2021-08-12'],\n 'status': '-',\n 'timeframe': 'summer',\n 'title': '\u7b2c\uff15\uff19\u56de\u30b9\u30dd\u30fc\u30c4\u30cb\u30c3\u30dd\u30f3\u8cde'},\n '\u5bae\u5cf6': {'day': '\u6700\u7d42\u65e5',\n 'grade': ['ippan'],\n 'period': ['2021-08-07', '2021-08-12'],\n 'status': '-',\n 'timeframe': '',\n 'title': '\u7b2c\uff15\uff11\u56de\u30b9\u30dd\u30fc\u30c4\u30cb\u30c3\u30dd\u30f3\u676f'},\n '\u5c3c\u5d0e': {'day': '\uff14\u65e5\u76ee',\n 'grade': ['ippan'],\n 'period': ['2021-08-09', '2021-08-14'],\n 'status': '-',\n 'timeframe': '',\n 'title': '\u65e5\u672c\u8ca1\u56e3\u4f1a\u9577\u676f\u4e89\u596a\u7b2c\uff14\uff19\u56de\u30aa\u30fc\u30eb\u5175\u5eab\u738b\u5ea7\u6c7a\u5b9a\u6226'},\n '\u5e38\u6ed1': {'day': '\uff12\u65e5\u76ee',\n 'grade': ['ippan'],\n 'period': ['2021-08-11', '2021-08-16'],\n 'status': '-',\n 'timeframe': '',\n 'title': '\u540d\u9244\u676f\u4e89\u596a\uff12\uff10\uff12\uff11\u7d0d\u6dbc\u304a\u76c6\u30ec\u30fc\u30b9'},\n '\u5e73\u548c\u5cf6': {'day': '\uff13\u65e5\u76ee',\n 'grade': ['ippan'],\n 'period': ['2021-08-10', '2021-08-15'],\n 'status': '-',\n 'timeframe': 'summer',\n 'title': '\u7b2c\uff16\uff11\u56de\u30c7\u30a4\u30ea\u30fc\u30b9\u30dd\u30fc\u30c4\u30b5\u30de\u30fc\u30ab\u30c3\u30d7'},\n '\u6238\u7530': {'day': '\u521d\u65e5',\n 'grade': ['ippan'],\n 'period': ['2021-08-12', '2021-08-17'],\n 'status': '-',\n 'timeframe': '',\n 'title': '\u7b2c\uff14\uff14\u56de\u6238\u7530\u30dc\u30fc\u30c8\u5927\u8cde\u30fb\u30b5\u30f3\u30b1\u30a4\u30b9\u30dd\u30fc\u30c4\u676f'},\n '\u6850\u751f': {'day': '\uff13\u65e5\u76ee',\n 'grade': ['ippan'],\n 'period': ['2021-08-10', '2021-08-15'],\n 'status': '-',\n 'timeframe': 'nighter',\n 'title': '\u7b2c\uff15\uff15\u56de\u5831\u77e5\u65b0\u805e\u793e\u676f\\u3000\u304a\u76c6\u30ec\u30fc\u30b9'},\n '\u82e5\u677e': {'day': '\uff14\u65e5\u76ee',\n 'grade': ['ippan'],\n 'period': ['2021-08-08', '2021-08-13'],\n 'status': '-',\n 'timeframe': 'nighter',\n 'title': '\u65e5\u520a\u30b9\u30dd\u30fc\u30c4\u676f\u304a\u76c6\u7279\u9078\u7af6\u8d70'},\n '\u84b2\u90e1': {'day': '\u521d\u65e5',\n 'grade': ['ippan'],\n 'period': ['2021-08-12', '2021-08-17'],\n 'status': '-',\n 'timeframe': 'nighter',\n 'title': '\u65e5\u520a\u30b9\u30dd\u30fc\u30c4\u676f\u4e89\u596a\\u3000\u7d0d\u6dbc\u3057\u3076\u304d\u304a\u76c6\u7279\u5225\u9078\u629c\u6226'},\n '\u9cf4\u9580': {'day': '\uff14\u65e5\u76ee',\n 'grade': ['ippan'],\n 'period': ['2021-08-09', '2021-08-14'],\n 'status': '-',\n 'timeframe': 'morning',\n 'title': '\u7b2c\uff15\uff14\u56de\u6e26\u738b\u676f\u7af6\u8d70'}}\n ```\n\n </details>\n\n- To get 12 races held in the given stadium on the given day:\n\n - API:\n\n - ```python\n PyJPBoatrace().get_12races(d: datetime.date, stadium: int) -> Dict[str, Any]\n ```\n\n - ```python\n PyJPBoatrace().Races.get(d: datetime.date, stadium: int) -> Dict[str, Any]\n ```\n\n - Return:\n <details>\n <summary> Sample </summary>\n\n ```python\n >>> from pyjpboatrace import PyJPBoatrace\n >>> from datetime import date\n >>> from pprint import pprint\n >>> pprint(PyJPBoatrace().get_12races(date(2021, 8, 12), 1))\n {'10R': {'racers': {'boat1': {'class': 'B1', 'name': '\u4f50\u85e4\u822a'},\n 'boat2': {'class': 'A1', 'name': '\u5927\u6fa4\u666e\u53f8'},\n 'boat3': {'class': 'A2', 'name': '\u6a4b\u672c\u4e45\u548c'},\n 'boat4': {'class': 'A1', 'name': '\u6c5f\u53e3\u6643\u751f'},\n 'boat5': {'class': 'B1', 'name': '\u571f\u5c4b\u592a\u6717'},\n 'boat6': {'class': 'A2', 'name': '\u52a0\u702c\u667a\u5b8f'}},\n 'status': '\u767a\u58f2\u7d42\u4e86',\n 'vote_limit': '2021-08-12 19:43:00'},\n '11R': {'racers': {'boat1': {'class': 'A2', 'name': '\u85e4\u751f\u96c4\u4eba'},\n 'boat2': {'class': 'A1', 'name': '\u6bd2\u5cf6\u8aa0'},\n 'boat3': {'class': 'A2', 'name': '\u9577\u8c37\u5ddd\u5145'},\n 'boat4': {'class': 'A1', 'name': '\u4e0a\u6751\u7d14\u4e00'},\n 'boat5': {'class': 'B1', 'name': '\u6d25\u4e45\u4e95\u62d3\u4e5f'},\n 'boat6': {'class': 'B1', 'name': '\u677e\u672c\u7d14\u5e73'}},\n 'status': '\u767a\u58f2\u7d42\u4e86',\n 'vote_limit': '2021-08-12 20:14:00'},\n '12R': {'racers': {'boat1': {'class': 'A1', 'name': '\u4e45\u7530\u654f\u4e4b'},\n 'boat2': {'class': 'A1', 'name': '\u91d1\u5b50\u62d3\u77e2'},\n 'boat3': {'class': 'A2', 'name': '\u6728\u6751\u6d69\u58eb'},\n 'boat4': {'class': 'A1', 'name': '\u690e\u540d\u8c4a'},\n 'boat5': {'class': 'A2', 'name': '\u672c\u6a4b\u514b\u6d0b'},\n 'boat6': {'class': 'A2', 'name': '\u91ce\u6751\u8aa0'}},\n 'status': '\u767a\u58f2\u7d42\u4e86',\n 'vote_limit': '2021-08-12 20:45:00'},\n '1R': {'racers': {'boat1': {'class': 'B1', 'name': '\u6e21\u8fba\u53f2\u4e4b'},\n 'boat2': {'class': 'B1', 'name': '\u5cf6\u5009\u90fd'},\n 'boat3': {'class': 'A2', 'name': '\u9ce5\u5c45\u585a\u5b5d\u535a'},\n 'boat4': {'class': 'B1', 'name': '\u677e\u672c\u7d14\u5e73'},\n 'boat5': {'class': 'A2', 'name': '\u6a4b\u672c\u4e45\u548c'},\n 'boat6': {'class': 'B2', 'name': '\u5bae\u5d0e\u5b89\u5948'}},\n 'status': '\u767a\u58f2\u7d42\u4e86',\n 'vote_limit': '2021-08-12 15:22:00'},\n '2R': {'racers': {'boat1': {'class': 'B1', 'name': '\u4f50\u53e3\u9054\u4e5f'},\n 'boat2': {'class': 'A2', 'name': '\u672c\u6a4b\u514b\u6d0b'},\n 'boat3': {'class': 'B1', 'name': '\u5bfa\u672c\u6607\u5e73'},\n 'boat4': {'class': 'B1', 'name': '\u6d25\u4e45\u4e95\u62d3\u4e5f'},\n 'boat5': {'class': 'B1', 'name': '\u4e45\u4fdd\u539f\u79c0\u4eba'},\n 'boat6': {'class': 'A2', 'name': '\u4e2d\u91cc\u82f1\u592b'}},\n 'status': '\u767a\u58f2\u7d42\u4e86',\n 'vote_limit': '2021-08-12 15:49:00'},\n '3R': {'racers': {'boat1': {'class': 'B1', 'name': '\u5c0f\u5ddd\u6642\u5149'},\n 'boat2': {'class': 'A2', 'name': '\u91ce\u6751\u8aa0'},\n 'boat3': {'class': 'B2', 'name': '\u9ec4\u91d1\u4e95\u88d5\u5b50'},\n 'boat4': {'class': 'A2', 'name': '\u85e4\u751f\u96c4\u4eba'},\n 'boat5': {'class': 'B1', 'name': '\u9ad8\u5c71\u79c0\u96c4'},\n 'boat6': {'class': 'A1', 'name': '\u95a2\u6d69\u54c9'}},\n 'status': '\u767a\u58f2\u7d42\u4e86',\n 'vote_limit': '2021-08-12 16:16:00'},\n '4R': {'racers': {'boat1': {'class': 'B1', 'name': '\u6817\u539f\u8b19\u6cbb'},\n 'boat2': {'class': 'A2', 'name': '\u91d1\u5b50\u8ce2\u5fd7'},\n 'boat3': {'class': 'B1', 'name': '\u95a2\u6839\u5f70\u4eba'},\n 'boat4': {'class': 'A1', 'name': '\u91d1\u5b50\u62d3\u77e2'},\n 'boat5': {'class': 'B2', 'name': '\u5927\u4e45\u4fdd\u4f51\u9999'},\n 'boat6': {'class': 'B1', 'name': '\u571f\u5c4b\u592a\u6717'}},\n 'status': '\u767a\u58f2\u7d42\u4e86',\n 'vote_limit': '2021-08-12 16:45:00'},\n '5R': {'racers': {'boat1': {'class': 'B1', 'name': '\u539f\u52a0\u592e\u7406'},\n 'boat2': {'class': 'B1', 'name': '\u4f50\u85e4\u822a'},\n 'boat3': {'class': 'B1', 'name': '\u8702\u9808\u745e\u751f'},\n 'boat4': {'class': 'A2', 'name': '\u4e00\u67f3\u548c\u5b5d'},\n 'boat5': {'class': 'B1', 'name': '\u5916\u5d0e\u609f'},\n 'boat6': {'class': 'A1', 'name': '\u6bd2\u5cf6\u8aa0'}},\n 'status': '\u767a\u58f2\u7d42\u4e86',\n 'vote_limit': '2021-08-12 17:13:00'},\n '6R': {'racers': {'boat1': {'class': 'A1', 'name': '\u690e\u540d\u8c4a'},\n 'boat2': {'class': 'B1', 'name': '\u4e45\u4fdd\u7530\u7f8e\u7d00'},\n 'boat3': {'class': 'B1', 'name': '\u592a\u7530\u514b\u54c9'},\n 'boat4': {'class': 'B1', 'name': '\u5cf6\u5009\u90fd'},\n 'boat5': {'class': 'B1', 'name': '\u91d1\u6fa4\u4e00\u6d0b'},\n 'boat6': {'class': 'B1', 'name': '\u5bfa\u672c\u6607\u5e73'}},\n 'status': '\u767a\u58f2\u7d42\u4e86',\n 'vote_limit': '2021-08-12 17:42:00'},\n '7R': {'racers': {'boat1': {'class': 'A2', 'name': '\u6728\u6751\u6d69\u58eb'},\n 'boat2': {'class': 'B1', 'name': '\u4e45\u4fdd\u539f\u79c0\u4eba'},\n 'boat3': {'class': 'A1', 'name': '\u4e0a\u6751\u7d14\u4e00'},\n 'boat4': {'class': 'B1', 'name': '\u9e7f\u5cf6\u654f\u5f18'},\n 'boat5': {'class': 'B2', 'name': '\u5bae\u5d0e\u5b89\u5948'},\n 'boat6': {'class': 'B2', 'name': '\u9ec4\u91d1\u4e95\u88d5\u5b50'}},\n 'status': '\u767a\u58f2\u7d42\u4e86',\n 'vote_limit': '2021-08-12 18:11:00'},\n '8R': {'racers': {'boat1': {'class': 'A2', 'name': '\u9ce5\u5c45\u585a\u5b5d\u535a'},\n 'boat2': {'class': 'B1', 'name': '\u9ad8\u5c71\u79c0\u96c4'},\n 'boat3': {'class': 'B1', 'name': '\u5409\u7530\u7a14'},\n 'boat4': {'class': 'B1', 'name': '\u7530\u4e2d\u5b9a\u96c4'},\n 'boat5': {'class': 'A1', 'name': '\u4e45\u7530\u654f\u4e4b'},\n 'boat6': {'class': 'B2', 'name': '\u5927\u4e45\u4fdd\u4f51\u9999'}},\n 'status': '\u767a\u58f2\u7d42\u4e86',\n 'vote_limit': '2021-08-12 18:41:00'},\n '9R': {'racers': {'boat1': {'class': 'B1', 'name': '\u5d0e\u5229\u4ec1'},\n 'boat2': {'class': 'A2', 'name': '\u4e2d\u91cc\u82f1\u592b'},\n 'boat3': {'class': 'B1', 'name': '\u585a\u539f\u6b66\u4e4b'},\n 'boat4': {'class': 'A1', 'name': '\u571f\u5c4b\u667a\u5247'},\n 'boat5': {'class': 'B1', 'name': '\u95a2\u6839\u5f70\u4eba'},\n 'boat6': {'class': 'A1', 'name': '\u5c71\u5d0e\u667a\u4e5f'}},\n 'status': '\u767a\u58f2\u7d42\u4e86',\n 'vote_limit': '2021-08-12 19:12:00'},\n 'date': '2021-08-12',\n 'stadium': 1}\n ```\n\n </details>\n\n- To get the basic information of the race in the stadium on a day:\n\n - API:\n\n - ```python\n PyJPBoatrace().get_race_info(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - ```python\n PyJPBoatrace().RaceInfo.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - Return:\n <details>\n <summary> Sample </summary>\n\n ```python\n >>> from pyjpboatrace import PyJPBoatrace\n >>> from datetime import date\n >>> from pprint import pprint\n >>> pprint(PyJPBoatrace().get_race_info(date(2021, 8, 12), 10, 1))\n {'boat1': {'F': 0,\n 'L': 0,\n 'age': 47,\n 'aveST': 0.16,\n 'birthplace': '\u798f\u4e95',\n 'boat': 13,\n 'boat_in2nd': 41.79,\n 'boat_in3rd': 58.21,\n 'branch': '\u798f\u4e95',\n 'class': 'A1',\n 'global_in2nd': 40.45,\n 'global_in3rd': 53.93,\n 'global_win_pt': 5.73,\n 'local_in2nd': 52.38,\n 'local_in3rd': 67.46,\n 'local_win_pt': 6.94,\n 'motor': 44,\n 'motor_in2nd': 53.42,\n 'motor_in3rd': 63.01,\n 'name': '\u6b66\u7530\u5149\u53f2',\n 'racerid': 3654,\n 'result': [{'ST': 0.19,\n 'boat': 5,\n 'course': 5,\n 'race': 6,\n 'rank': 4},\n {'ST': 0.14,\n 'boat': 3,\n 'course': 3,\n 'race': 12,\n 'rank': 5},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {}],\n 'weight': 52.6},\n 'boat2': {'F': 0,\n 'L': 0,\n 'age': 25,\n 'aveST': 0.21,\n 'birthplace': '\u611b\u77e5',\n 'boat': 64,\n 'boat_in2nd': 22.67,\n 'boat_in3rd': 36.0,\n 'branch': '\u611b\u77e5',\n 'class': 'B1',\n 'global_in2nd': 10.17,\n 'global_in3rd': 20.34,\n 'global_win_pt': 3.18,\n 'local_in2nd': 3.33,\n 'local_in3rd': 3.33,\n 'local_win_pt': 2.0,\n 'motor': 24,\n 'motor_in2nd': 42.67,\n 'motor_in3rd': 68.0,\n 'name': '\u5927\u6fa4\u8aa0\u4e5f',\n 'racerid': 5074,\n 'result': [{'ST': 0.19,\n 'boat': 3,\n 'course': 3,\n 'race': 6,\n 'rank': 3},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {}],\n 'weight': 53.1},\n 'boat3': {'F': 0,\n 'L': 0,\n 'age': 45,\n 'aveST': 0.17,\n 'birthplace': '\u611b\u77e5',\n 'boat': 41,\n 'boat_in2nd': 29.33,\n 'boat_in3rd': 52.0,\n 'branch': '\u611b\u77e5',\n 'class': 'B1',\n 'global_in2nd': 29.79,\n 'global_in3rd': 54.26,\n 'global_win_pt': 5.39,\n 'local_in2nd': 31.48,\n 'local_in3rd': 51.85,\n 'local_win_pt': 5.09,\n 'motor': 51,\n 'motor_in2nd': 49.32,\n 'motor_in3rd': 63.01,\n 'name': '\u5800\u672c\u88d5\u4e5f',\n 'racerid': 3895,\n 'result': [{'ST': 0.06,\n 'boat': 5,\n 'course': 5,\n 'race': 4,\n 'rank': 5},\n {'ST': 0.2,\n 'boat': 2,\n 'course': 2,\n 'race': 11,\n 'rank': 4},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {}],\n 'weight': 50.0},\n 'boat4': {'F': 0,\n 'L': 0,\n 'age': 47,\n 'aveST': 0.18,\n 'birthplace': '\u77f3\u5ddd',\n 'boat': 36,\n 'boat_in2nd': 32.43,\n 'boat_in3rd': 44.59,\n 'branch': '\u798f\u4e95',\n 'class': 'B1',\n 'global_in2nd': 17.17,\n 'global_in3rd': 29.29,\n 'global_win_pt': 3.99,\n 'local_in2nd': 21.59,\n 'local_in3rd': 35.23,\n 'local_win_pt': 4.45,\n 'motor': 41,\n 'motor_in2nd': 45.95,\n 'motor_in3rd': 64.86,\n 'name': '\u4fe1\u6fc3\u7531\u884c',\n 'racerid': 3620,\n 'result': [{'ST': 0.26,\n 'boat': 5,\n 'course': 3,\n 'race': 3,\n 'rank': 5},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {}],\n 'weight': 52.3},\n 'boat5': {'F': 0,\n 'L': 0,\n 'age': 30,\n 'aveST': 0.19,\n 'birthplace': '\u77f3\u5ddd',\n 'boat': 17,\n 'boat_in2nd': 21.79,\n 'boat_in3rd': 46.15,\n 'branch': '\u798f\u4e95',\n 'class': 'B1',\n 'global_in2nd': 37.5,\n 'global_in3rd': 56.73,\n 'global_win_pt': 5.56,\n 'local_in2nd': 35.04,\n 'local_in3rd': 52.55,\n 'local_win_pt': 5.53,\n 'motor': 61,\n 'motor_in2nd': 43.28,\n 'motor_in3rd': 64.18,\n 'name': '\u6728\u7530\u5cf0\u7531\u5b63',\n 'racerid': 4587,\n 'result': [{'ST': 0.19,\n 'boat': 2,\n 'course': 2,\n 'race': 3,\n 'rank': 3},\n {'ST': 0.21,\n 'boat': 4,\n 'course': 5,\n 'race': 10,\n 'rank': 2},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {}],\n 'weight': 52.2},\n 'boat6': {'F': 0,\n 'L': 0,\n 'age': 21,\n 'aveST': '-',\n 'birthplace': '\u798f\u4e95',\n 'boat': 15,\n 'boat_in2nd': 26.76,\n 'boat_in3rd': 39.44,\n 'branch': '\u798f\u4e95',\n 'class': 'B2',\n 'global_in2nd': 0.0,\n 'global_in3rd': 0.0,\n 'global_win_pt': 1.29,\n 'local_in2nd': 0.0,\n 'local_in3rd': 0.0,\n 'local_win_pt': 1.0,\n 'motor': 54,\n 'motor_in2nd': 43.84,\n 'motor_in3rd': 63.01,\n 'name': '\u52a0\u85e4\u512a\u5f25',\n 'racerid': 5185,\n 'result': [{'ST': 0.01,\n 'boat': 6,\n 'course': 6,\n 'race': 4,\n 'rank': 6},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {},\n {}],\n 'weight': 52.6},\n 'date': '2021-08-12',\n 'race': 1,\n 'race_title': ['\u307f\u304f\u306b\u3042\u3055\u30a4\u30c1', '1800m'],\n 'stadium': 10}\n ```\n\n </details>\n\n- To get the odds of win (\u5358\u52dd) and place-show (\u8907\u52dd) of the race in the stadium on the day:\n\n - API:\n\n - ```python\n PyJPBoatrace().get_odds_win_placeshow(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - ```python\n PyJPBoatrace().WinPlaceshowOdds.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - Return:\n <details>\n <summary> Sample </summary>\n\n ```python\n >>> from pyjpboatrace import PyJPBoatrace\n >>> from datetime import date\n >>> from pprint import pprint\n >>> pprint(PyJPBoatrace().get_odds_win_placeshow(date(2021, 8, 12), 10, 1))\n {'date': '2021-08-12',\n 'place_show': {'1': [1.0, 1.0],\n '2': [2.5, 7.0],\n '3': [2.0, 5.5],\n '4': [2.3, 6.4],\n '5': [1.5, 4.0],\n '6': [3.8, 10.6]},\n 'race': 1,\n 'stadium': 10,\n 'update': '\u7de0\u5207\u6642\u30aa\u30c3\u30ba',\n 'win': {'1': 1.0, '2': 20.7, '3': 11.0, '4': 18.4, '5': 23.6, '6': 27.6}}\n ```\n\n </details>\n\n- To get the odds of quinella place (\u62e1\u9023\u8907) of the race in the stadioum on the day:\n\n - API:\n\n - ```python\n PyJPBoatrace().get_odds_quinellaplace(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - ```python\n PyJPBoatrace().QuinellaplaceOdds.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - Return:\n <details>\n <summary> Sample </summary>\n\n ```python\n >>> from pyjpboatrace import PyJPBoatrace\n >>> from datetime import date\n >>> from pprint import pprint\n >>> pprint(PyJPBoatrace().get_odds_quinellaplace(date(2021, 8, 12), 10, 1))\n {'1=2': [1.6, 2.1],\n '1=3': [1.1, 1.4],\n '1=4': [3.7, 5.0],\n '1=5': [1.1, 1.4],\n '1=6': [18.1, 23.4],\n '2=3': [6.1, 9.9],\n '2=4': [10.6, 13.0],\n '2=5': [4.1, 6.4],\n '2=6': [30.1, 34.8],\n '3=4': [5.1, 7.1],\n '3=5': [1.9, 3.4],\n '3=6': [16.9, 22.4],\n '4=5': [6.4, 8.9],\n '4=6': [50.0, 51.9],\n '5=6': [16.0, 20.9],\n 'date': '2021-08-12',\n 'race': 1,\n 'stadium': 10,\n 'update': '\u7de0\u5207\u6642\u30aa\u30c3\u30ba'}\n ```\n\n </details>\n\n- To get the odds of exacta (\u4e8c\u9023\u5358) and quinella (\u4e8c\u9023\u8907) of the race in the stadioum on the day:\n\n - API:\n\n - ```python\n PyJPBoatrace().get_odds_exacta_quinella(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - ```python\n PyJPBoatrace().ExactaQuinellaOdds.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - Return:\n <details>\n <summary> Sample </summary>\n\n ```python\n >>> from pyjpboatrace import PyJPBoatrace\n >>> from datetime import date\n >>> from pprint import pprint\n >>> pprint(PyJPBoatrace().get_odds_exacta_quinella(date(2021, 8, 12), 10, 1))\n {'date': '2021-08-12',\n 'exacta': {'1-2': 4.8,\n '1-3': 2.6,\n '1-4': 7.2,\n '1-5': 4.0,\n '1-6': 63.9,\n '2-1': 26.4,\n '2-3': 75.9,\n '2-4': 291.8,\n '2-5': 132.6,\n '2-6': 810.5,\n '3-1': 15.9,\n '3-2': 94.7,\n '3-4': 110.5,\n '3-5': 41.2,\n '3-6': 429.1,\n '4-1': 66.9,\n '4-2': 260.5,\n '4-3': 187.0,\n '4-5': 105.7,\n '4-6': 455.9,\n '5-1': 13.5,\n '5-2': 74.4,\n '5-3': 47.9,\n '5-4': 70.8,\n '5-6': 97.2,\n '6-1': 347.3,\n '6-2': 663.2,\n '6-3': 729.5,\n '6-4': 729.5,\n '6-5': 455.9},\n 'quinella': {'1=2': 4.8,\n '1=3': 1.8,\n '1=4': 6.1,\n '1=5': 4.4,\n '1=6': 73.8,\n '2=3': 79.5,\n '2=4': 94.0,\n '2=5': 36.9,\n '2=6': 172.3,\n '3=4': 64.6,\n '3=5': 16.6,\n '3=6': 206.8,\n '4=5': 33.3,\n '4=6': 172.3,\n '5=6': 129.2},\n 'race': 1,\n 'stadium': 10,\n 'update': '\u7de0\u5207\u6642\u30aa\u30c3\u30ba'}\n ```\n\n </details>\n\n- To get the odds of trifecta (\u4e09\u9023\u5358) of the race in the stadioum on the day:\n\n - API:\n\n - ```python\n PyJPBoatrace().get_odds_trifecta(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - ```python\n PyJPBaotrace().TrifectaOdds.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - Return:\n <details>\n <summary> Sample </summary>\n\n ```python\n >>> from pyjpboatrace import PyJPBoatrace\n >>> from datetime import date\n >>> from pprint import pprint\n >>> pprint(PyJPBoatrace().get_odds_trifecta(date(2021, 8, 12), 10, 1))\n {'1-2-3': 12.1,\n '1-2-4': 22.8,\n '1-2-5': 10.7,\n '1-2-6': 136.2,\n '1-3-2': 11.2,\n '1-3-4': 9.5,\n '1-3-5': 5.2,\n '1-3-6': 101.2,\n '1-4-2': 33.9,\n '1-4-3': 19.2,\n '1-4-5': 18.8,\n '1-4-6': 169.1,\n '1-5-2': 11.9,\n '1-5-3': 7.3,\n '1-5-4': 16.0,\n '1-5-6': 81.5,\n '1-6-2': 400.4,\n '1-6-3': 357.7,\n '1-6-4': 399.1,\n '1-6-5': 297.0,\n '2-1-3': 143.1,\n '2-1-4': 251.5,\n '2-1-5': 135.8,\n '2-1-6': 759.3,\n '2-3-1': 274.6,\n '2-3-4': 926.4,\n '2-3-5': 574.7,\n '2-3-6': 1866.0,\n '2-4-1': 715.5,\n '2-4-3': 1247.0,\n '2-4-5': 981.4,\n '2-4-6': 2853.0,\n '2-5-1': 256.5,\n '2-5-3': 542.1,\n '2-5-4': 838.8,\n '2-5-6': 1306.0,\n '2-6-1': 2789.0,\n '2-6-3': 3103.0,\n '2-6-4': 4138.0,\n '2-6-5': 2342.0,\n '3-1-2': 81.8,\n '3-1-4': 69.4,\n '3-1-5': 35.9,\n '3-1-6': 403.0,\n '3-2-1': 238.0,\n '3-2-4': 709.4,\n '3-2-5': 432.5,\n '3-2-6': 1469.0,\n '3-4-1': 206.0,\n '3-4-2': 684.0,\n '3-4-5': 226.7,\n '3-4-6': 1591.0,\n '3-5-1': 82.6,\n '3-5-2': 282.4,\n '3-5-4': 221.2,\n '3-5-6': 775.9,\n '3-6-1': 1970.0,\n '3-6-2': 2364.0,\n '3-6-4': 3027.0,\n '3-6-5': 2387.0,\n '4-1-2': 330.1,\n '4-1-3': 207.7,\n '4-1-5': 179.9,\n '4-1-6': 989.2,\n '4-2-1': 780.8,\n '4-2-3': 1452.0,\n '4-2-5': 977.5,\n '4-2-6': 2789.0,\n '4-3-1': 477.4,\n '4-3-2': 1286.0,\n '4-3-5': 556.7,\n '4-3-6': 2586.0,\n '4-5-1': 259.4,\n '4-5-2': 598.3,\n '4-5-3': 399.1,\n '4-5-6': 1030.0,\n '4-6-1': 2728.0,\n '4-6-2': 3310.0,\n '4-6-3': 3762.0,\n '4-6-5': 3267.0,\n '5-1-2': 67.2,\n '5-1-3': 46.4,\n '5-1-4': 103.0,\n '5-1-6': 287.0,\n '5-2-1': 197.0,\n '5-2-3': 420.8,\n '5-2-4': 656.8,\n '5-2-6': 1205.0,\n '5-3-1': 100.8,\n '5-3-2': 324.9,\n '5-3-4': 332.8,\n '5-3-6': 1149.0,\n '5-4-1': 258.3,\n '5-4-2': 625.4,\n '5-4-3': 414.5,\n '5-4-6': 1286.0,\n '5-6-1': 800.9,\n '5-6-2': 1205.0,\n '5-6-3': 1279.0,\n '5-6-4': 1724.0,\n '6-1-2': 2320.0,\n '6-1-3': 2257.0,\n '6-1-4': 2921.0,\n '6-1-5': 1786.0,\n '6-2-1': 4070.0,\n '6-2-3': 4514.0,\n '6-2-4': 5643.0,\n '6-2-5': 2921.0,\n '6-3-1': 3598.0,\n '6-3-2': 4774.0,\n '6-3-4': 4433.0,\n '6-3-5': 2387.0,\n '6-4-1': 4514.0,\n '6-4-2': 6534.0,\n '6-4-3': 4138.0,\n '6-4-5': 4004.0,\n '6-5-1': 2559.0,\n '6-5-2': 2698.0,\n '6-5-3': 4070.0,\n '6-5-4': 4774.0,\n 'date': '2021-08-12',\n 'race': 1,\n 'stadium': 10,\n 'update': '\u7de0\u5207\u6642\u30aa\u30c3\u30ba'}\n ```\n\n </details>\n\n- To get the oods of trio \uff08\u4e09\u9023\u8907\uff09 of the race in the stadioum on the day:\n\n - API:\n\n - ```python\n PyJPBoatrace().get_odds_trio(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - ```python\n PyJPBoatrace().Trio.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - Return:\n <details>\n <summary> Sample </summary>\n\n ```python\n >>> from pyjpboatrace import PyJPBoatrace\n >>> from datetime import date\n >>> from pprint import pprint\n >>> pprint(PyJPBoatrace().get_odds_trio(date(2021, 8, 12), 10, 1))\n {'1=2=3': 5.1,\n '1=2=4': 14.6,\n '1=2=5': 4.7,\n '1=2=6': 73.8,\n '1=3=4': 5.9,\n '1=3=5': 2.5,\n '1=3=6': 73.8,\n '1=4=5': 6.4,\n '1=4=6': 106.6,\n '1=5=6': 59.0,\n '2=3=4': 98.4,\n '2=3=5': 36.2,\n '2=3=6': 295.3,\n '2=4=5': 93.6,\n '2=4=6': 426.5,\n '2=5=6': 159.9,\n '3=4=5': 45.7,\n '3=4=6': 548.4,\n '3=5=6': 191.9,\n '4=5=6': 213.2,\n 'date': '2021-08-12',\n 'race': 1,\n 'stadium': 10,\n 'update': '\u7de0\u5207\u6642\u30aa\u30c3\u30ba'}\n ```\n\n </details>\n\n- To get the just-before information, e.g. weather and start-timing, of the race in the stadioum on the day:\n\n - API:\n\n - ```python\n PyJPBoatrace().get_just_before_info(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - ```python\n PyJPBoatrace().JustBeforeInfo.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - Return:\n <details>\n <summary> Sample </summary>\n\n ```python\n >>> from pyjpboatrace import PyJPBoatrace\n >>> from datetime import date\n >>> from pprint import pprint\n >>> pprint(PyJPBoatrace().get_just_before_info(date(2021, 8, 12), 10, 1))\n {'boat1': {'display_time': 6.77,\n 'name': '\u6b66\u7530\u5149\u53f2',\n 'parts_exchange': [],\n 'previous_race': {},\n 'propeller': '',\n 'tilt': -0.5,\n 'weight': 52.6,\n 'weight_adjustment': 0.0},\n 'boat2': {'display_time': 6.76,\n 'name': '\u5927\u6fa4\u8aa0\u4e5f',\n 'parts_exchange': [],\n 'previous_race': {},\n 'propeller': '',\n 'tilt': -0.5,\n 'weight': 53.1,\n 'weight_adjustment': 0.0},\n 'boat3': {'display_time': 6.77,\n 'name': '\u5800\u672c\u88d5\u4e5f',\n 'parts_exchange': [],\n 'previous_race': {},\n 'propeller': '',\n 'tilt': -0.5,\n 'weight': 50.0,\n 'weight_adjustment': 2.0},\n 'boat4': {'display_time': 6.77,\n 'name': '\u4fe1\u6fc3\u7531\u884c',\n 'parts_exchange': [],\n 'previous_race': {},\n 'propeller': '',\n 'tilt': -0.5,\n 'weight': 52.3,\n 'weight_adjustment': 0.0},\n 'boat5': {'display_time': 6.79,\n 'name': '\u6728\u7530\u5cf0\u7531\u5b63',\n 'parts_exchange': [],\n 'previous_race': {},\n 'propeller': '',\n 'tilt': -0.5,\n 'weight': 52.2,\n 'weight_adjustment': 0.0},\n 'boat6': {'display_time': 6.81,\n 'name': '\u52a0\u85e4\u512a\u5f25',\n 'parts_exchange': [],\n 'previous_race': {},\n 'propeller': '',\n 'tilt': -0.5,\n 'weight': 52.6,\n 'weight_adjustment': 0.0},\n 'date': '2021-08-12',\n 'race': 1,\n 'stadium': 10,\n 'start_display': {'course1': {'ST': 0.11, 'boat': 1},\n 'course2': {'ST': 0.13, 'boat': 2},\n 'course3': {'ST': 0.22, 'boat': 3},\n 'course4': {'ST': 0.17, 'boat': 4},\n 'course5': {'ST': 0.11, 'boat': 5},\n 'course6': {'ST': 0.13, 'boat': 6}},\n 'weather_information': {'direction': 14,\n 'temperature': 25.0,\n 'time': '14:53\u73fe\u5728',\n 'water_temperature': 27.0,\n 'wave_height': 1.0,\n 'weather': '\u66c7\u308a',\n 'wind_direction': 2,\n 'wind_speed': 1.0}}\n ```\n\n </details>\n\n- To get the race result of the race in the stadioum on the day:\n\n - API:\n\n - ```python\n PyJPBoatrace().get_race_result(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - ```python\n PyJPBoatrace().Result.get(d: datetime.date, stadium: int, race: int) -> Dict[str, Any]\n ```\n\n - Return:\n <details>\n <summary> Sample </summary>\n\n ```python\n >>> from pyjpboatrace import PyJPBoatrace\n >>> from datetime import date\n >>> from pprint import pprint\n >>> pprint(PyJPBoatrace().get_race_result(date(2021, 8, 12), 10, 1))\n {'date': '2021-08-12',\n 'kimarite': '\u9003\u3052',\n 'note': [],\n 'payoff': {'exacta': {'payoff': 400, 'popularity': 2, 'result': '1-5'},\n 'exacta_all': [{'payoff': 400, 'popularity': 2, 'result': '1-5'}],\n 'place_show': [{'payoff': 100, 'popularity': '', 'result': '1'},\n {'payoff': 150, 'popularity': '', 'result': '5'}],\n 'place_show_all': [{'payoff': 100, 'popularity': '', 'result': '1'},\n {'payoff': 150,\n 'popularity': '',\n 'result': '5'}],\n 'quinella': {'payoff': 440, 'popularity': 2, 'result': '1=5'},\n 'quinella_all': [{'payoff': 440, 'popularity': 2, 'result': '1=5'}],\n 'quinella_place': [{'payoff': 110,\n 'popularity': 2,\n 'result': '1=5'},\n {'payoff': 110,\n 'popularity': 1,\n 'result': '1=3'},\n {'payoff': 190,\n 'popularity': 4,\n 'result': '3=5'}],\n 'quinella_place_all': [{'payoff': 110,\n 'popularity': 2,\n 'result': '1=5'},\n {'payoff': 110,\n 'popularity': 1,\n 'result': '1=3'},\n {'payoff': 190,\n 'popularity': 4,\n 'result': '3=5'}],\n 'trifecta': {'payoff': 730, 'popularity': 2, 'result': '1-5-3'},\n 'trifecta_all': [{'payoff': 730,\n 'popularity': 2,\n 'result': '1-5-3'}],\n 'trio': {'payoff': 250, 'popularity': 1, 'result': '1=3=5'},\n 'trio_all': [{'payoff': 250, 'popularity': 1, 'result': '1=3=5'}],\n 'win': {'payoff': 100, 'popularity': '', 'result': '1'},\n 'win_all': [{'payoff': 100, 'popularity': '', 'result': '1'}]},\n 'race': 1,\n 'result': [{'boat': 1,\n 'name': '\u6b66\u7530\u5149\u53f2',\n 'racerid': 3654,\n 'rank': 1,\n 'time': '1\\'49\"2'},\n {'boat': 5,\n 'name': '\u6728\u7530\u5cf0\u7531\u5b63',\n 'racerid': 4587,\n 'rank': 2,\n 'time': '1\\'50\"8'},\n {'boat': 3,\n 'name': '\u5800\u672c\u88d5\u4e5f',\n 'racerid': 3895,\n 'rank': 3,\n 'time': '1\\'52\"6'},\n {'boat': 2,\n 'name': '\u5927\u6fa4\u8aa0\u4e5f',\n 'racerid': 5074,\n 'rank': 4,\n 'time': '1\\'54\"1'},\n {'boat': 6, 'name': '\u52a0\u85e4\u512a\u5f25', 'racerid': 5185, 'rank': 5, 'time': ''},\n {'boat': 4,\n 'name': '\u4fe1\u6fc3\u7531\u884c',\n 'racerid': 3620,\n 'rank': 6,\n 'time': ''}],\n 'return': [],\n 'stadium': 10,\n 'start_information': {'course1': {'ST': 0.26, 'boat': 1},\n 'course2': {'ST': 0.25, 'boat': 2},\n 'course3': {'ST': 0.23, 'boat': 3},\n 'course4': {'ST': 0.25, 'boat': 4},\n 'course5': {'ST': 0.21, 'boat': 5},\n 'course6': {'ST': 0.17, 'boat': 6}},\n 'weather_information': {'direction': 14,\n 'temperature': 27.0,\n 'water_temperature': 26.0,\n 'wave_height': 1,\n 'weather': '\u66c7\u308a',\n 'wind_direction': 12,\n 'wind_speed': 1}}\n ```\n\n </details>\n\n - NOTE: you may be confused by the output of `PyJPBoatrace().get_race_result` because the contents of \"payoff\" key in the output have the following keys:\n\n - \"exacta\"\n - \"exacta_all\"\n - \"place_show\"\n - \"place_show_all\"\n - \"quinella\"\n - \"quinella_all\"\n - \"quinella_place\"\n - \"quinella_place_all\"\n - \"trifecta\"\n - \"trifecta_all\"\n - \"trio\"\n - \"trio_all\"\n - \"win\"\n - \"win_all\"\n\n For \"win\", \"exacta\", \"quinella\", \"trifecta\" and \"trio\", the difference between a key without \"all\" footer and a key with \"all\" footer is that the former means ONE result while the latter means ALL results.\n For example, if \"1-2-3\" and \"1-2-4\" is hit as trifecta in a race, that is, if 3rd boat and 4th boat are tied for third place, the valud of \"trifecta\" key is `{'payoff': ..., 'popularity': ..., 'result': '1-2-3'}` while the value of \"trifecta_all\" key is `[{'payoff': ..., 'popularity': ..., 'result': '1-2-3'}, {'payoff': ..., 'popularity': ..., 'result': '1-2-4'}]`.\n On the other hand, for \"place_show\" and \"quinella_place\", there is no difference between a key without \"all\" footer and a key with \"all\" footer.\n\nThese functions return `dict` object.\n\n#### Operations\n\n- To deposit money for betting (Unit: 1,000 yen):\n - API\n - `PyJPBoatrace().deposit(num_of_thousands_yen: int) -> None`\n - `PyJPBoatrace().Deposit.do(num_of_thousands_yen: int) -> None`\n - Return:\n - Nothing\n- To get the limit of betting amount, that is, your current deposit:\n - API\n - `PyJPBoatrace().get_bet_limit() -> int`\n - `PyJPBoatrace().BettingLimitCheck.do() -> int`\n - Return:\n - `int`: the amount of deposit\n- To withdraw your current deposit:\n\n - API:\n\n - `PyJPBoatrace().withdraw() -> None`\n - `PyJPBoatrace().Widthdraw.do() -> None`\n\n - Return:\n - Nothing\n\n- To bet some tickets.\n\n - API:\n\n - ```python\n PyJPBoatrace().bet(\n stadium:int,\n race:int,\n trifecta_betting_dict: Dict[str, int],\n trio_betting_dict: Dict[str, int],\n exacta_betting_dict: Dict[str, int],\n quinela_betting_dict: Dict[str, int],\n quinellaplace_betting_dict: Dict[str, int],\n win_betting_dict: Dict[str, int],\n placeshow_betting_dict: Dict[str, int],\n ) -> bool\n ```\n\n - ```python\n PyJPBoatrace().Bet.do(\n stadium:int,\n race:int,\n trifecta_betting_dict: Dict[str, int],\n trio_betting_dict: Dict[str, int],\n exacta_betting_dict: Dict[str, int],\n quinela_betting_dict: Dict[str, int],\n quinellaplace_betting_dict: Dict[str, int],\n win_betting_dict: Dict[str, int],\n placeshow_betting_dict: Dict[str, int],\n ) -> bool\n ```\n\n - Each dictionary consits of pairs of winning numbers and betting amount, e.g., `{'1-2-3':100}` for trifecta_betting_dict\n\nIMPORTANT NOTE: you must give a driver other than `HTTPGetDriver` to use above actions.\n\n### Demo\n\n#### Demo 1 : Getting odds data\n\nThe following example is useful.\nSuppose that you want get the odds of trifecta of 4th race in stadium \"\u6850\u751f\" on 2020/12/02 and dump the result into `data.json`.\n\n```python\nfrom datetime import date\nimport json\nfrom pyjpboatrace import PyJPBoatrace\n\n# initialize\nboatrace_tools = PyJPBoatrace()\n\n# get data\ndic = boatrace_tools.get_odds_trifecta(d=date(2020,12,2), stadium=1, race=4)\n\n# dump data\nwith open('data.json', 'w', encoding='utf-8') as f:\n json.dump(dic, f, ensure_ascii=False)\n\n# close (you can use 'with' statement)\nboatrace_tools.close()\n```\n\nYou can get many kinds of data as this example.\n\n#### Demo 2 : Betting\n\nSuppose it is 2020/12/02 and you want to bet 200 yen on trifecta 1-3-4 and 100 yen on trio 1=3=4 in the 2nd race in stadium \"\u6850\u751f\" on 2020/12/02. NOTE: you need google chrome in the following example.\n\n```python\nfrom datetime import date\nfrom pyjpboatrace import PyJPBoatrace\nfrom pyjpboatrace.drivers import create_chrome_driver\nfrom pyjpboatrace.const import STADIUMS_MAP\nfrom pyjpboatrace.user_information import UserInformation\n\n# initialize\nuser = UserInformation(\n userid='YOUR_USER_ID',\n pin='YOUR_PIN',\n auth_pass='YOUR_AUTHENTIFICATION_PASSWORD',\n vote_pass='YOUR_BETTING_PASSWORD',\n)\nboatrace_tools = PyJPBoatrace(\n driver=create_chrome_driver(),\n user_information=user\n)\n\n# deposit 1,000 yen\nboatrace_tools.deposit(1)\n\n# bet\nstadium = {s:i for i,s in STADIUMS_MAP}.get(\"\u6850\u751f\")\nrace = 2\nboatrace_tools.bet(\n stadium=stadium,\n race=race,\n trifecta_betting_dict={'1-3-4':200},\n trio_betting_dict={'1=3=4':100}\n)\n\n# waiting for the race result ...\n\n# withdraw\nboatrace_tools.withdraw()\n\n# close (you can use 'with' statement)\nboatrace_tools.close()\n```\n\n### NOTE\n\nThe map between integers and stadiums is given by `STADIUMS_MAP` in `pyjpboatrace.const`.\n\n## Contribution Guide\n\n### Requirement\n\n- Python >= 3.8\n- Chrome\n- Firefox\n- bash\n- curl\n\n### Issues\n\n- For any bugs, use [BUG REPORT](https://github.com/hmasdev/pyjpboatrace/issues/new?assignees=&labels=bug&template=bug_report.md&title=%5BBUG%5D) to create an issue.\n\n- For any enhancement, use [FEATURE REQUEST](https://github.com/hmasdev/pyjpboatrace/issues/new?assignees=&labels=enhancement&template=feature_request.md&title=) to create an issue.\n\n- For other topics, create an issue with a clear and concise description.\n\n### Pull Request\n\n1. Fork ([https://github.com/hmasdev/pyjpboatrace/fork](https://github.com/hmasdev/pyjpboatrace/fork));\n2. Create your feature branch (`git checkout -b feautre/xxxx`);\n3. Test codes according to [Test Subsection](#HowToTestAnchor);\n4. Commit your changes (`git commit -am 'Add xxxx feature`);\n5. Push to the branch (`git push origin feature/xxxx`);\n6. Create new Pull Request\n\n### Setup the develop environment\n\nFirst, fork this repository and clone it to your local machine.\n\n```bash\ngit clone https://github.com/hmasdev/pyjpboatrace/\ncd pyjpboatrace\n```\n\nThen, create a virtual environment for your development,\nand install the required libraries.\n\n```bash\npython -m venv venv\nsource venv/bin/activate # for Linux or MacOS\n# venv\\Scripts\\activate # for Windows\npip install -e .[dev]\n```\n\n<details>\n<summary>[Deprecated] when using `pipenv`</summary>\n\n```bash\npipenv sync --dev\n```\n\n</details>\n\n### Test\n\n<div id=\"HowToTestAnchor\"></div>\n\nYou can do unit tests and integration tests as follows:\n\n```bash\n./download_html_for_test.sh # Only 1 time\npytest -m \"not integrate and not spending_money\" # unit tests\npytest # unit tests and integration tests\n```\n\n<details>\n<summary>[Deprecated] when using `pipenv`</summary>\n\n```bash\n./download_html_for_test.sh # Only 1 time\npipenv run pytest -m \"not integrate and not spending_money\" # unit tests\npipenv run pytest # unit tests and integration tests\n```\n\n</details>\n\n`pytest` does not test depositing, withdrawing or betting.\nIf you want to test them, make `.secrets.json` at first:\n\n```json\n{\n \"userid\": \"YOUR_USER_ID\",\n \"pin\": \"YOUR_PIN\",\n \"auth_pass\": \"YOUR_AUTHENTIFICATION_PASSWORD\",\n \"vote_pass\": \"YOUR_BETTING_PASSWORD\"\n}\n```\n\nThen, run\n\n```bash\npytest -m \"spending_money\"\n```\n\n<details>\n<summary>[Deprecated] when using `pipenv`</summary>\n\n```bash\npipenv run pytest -m \"spending_money\"\n```\n\n</details>\n\nWARNING: Tests with `spending_money` spend 700 yen.\n\n### Check the format of code and static types\n\nYou should execute the following codes to check the format of code and static types:\n\n```bash\nflake8 pyjpboatrace tests\nmypy pyjpboatrace tests\n```\n\n<details>\n<summary>[Deprecated] when using `pipenv`</summary>\n\n```bash\npipenv run flake8 pyjpboatrace\npipenv run flake8 tests\npipenv run mypy pyjpboatrace\npipenv run mypy tests\n```\n\n</details>\n\n### How to Update README.md\n\nTo update the content of [README.md](./README.md), please do not edit the file directly.\nInstead, make your changes to [README.md.j2](./README.md.j2).\n\nAfter making updates to `README.md.j2`, execute the following command to regenerate `README.md`:\n\n```bash\npython update_readme.py > README.md\n```\n\nThis process is necessary because README.md is dynamically generated from the README.md.j2 template.\nDirect modifications to README.md will be lost, as they are automatically overwritten by an automated process whenever the template is updated.\n\nRemember, to preserve your changes, always update README.md.j2 and not README.md directly.\n\n## LICENSE\n\n[MIT](https://github.com/hmasdev/pyjpboatrace/tree/main/LICENSE)\n\n## Authors\n\n[hmasdev](https://github.com/hmasdev)\n",
"bugtrack_url": null,
"license": "MIT License Copyright (c) 2020 hmasdev Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the \"Software\"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ",
"summary": "PyJPBoatrace: Python-based Japanese boatrace tools",
"version": "0.3.1",
"project_urls": {
"Repository": "http://github.com/hmasdev/pyjpboatrace"
},
"split_keywords": [
"kyotei",
" boatrace",
" data analysis"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "ecdd5cc0e03437a691c95c444dbf3da3196b13e258cd64cae23da566870a3ed2",
"md5": "3596c2284cb36650c7bf4a5947e5b689",
"sha256": "9c79a0492043a10159a60d340498730e5743e3de5895d6fa56f9cb660e8dbe91"
},
"downloads": -1,
"filename": "pyjpboatrace-0.3.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "3596c2284cb36650c7bf4a5947e5b689",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.8",
"size": 20534,
"upload_time": "2024-06-01T16:36:53",
"upload_time_iso_8601": "2024-06-01T16:36:53.705827Z",
"url": "https://files.pythonhosted.org/packages/ec/dd/5cc0e03437a691c95c444dbf3da3196b13e258cd64cae23da566870a3ed2/pyjpboatrace-0.3.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "dd47bcc473c5f34af3409952c9381f7d597b13dbbb255d8829fb9816973badee",
"md5": "299f7051c4ce75a53e350400dc1e5f5d",
"sha256": "5391bc0adef5d319af08c4d718787bccd2e4914e44d48d7a005fb2a7c2a4494f"
},
"downloads": -1,
"filename": "pyjpboatrace-0.3.1.tar.gz",
"has_sig": false,
"md5_digest": "299f7051c4ce75a53e350400dc1e5f5d",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.8",
"size": 41785,
"upload_time": "2024-06-01T16:36:55",
"upload_time_iso_8601": "2024-06-01T16:36:55.585700Z",
"url": "https://files.pythonhosted.org/packages/dd/47/bcc473c5f34af3409952c9381f7d597b13dbbb255d8829fb9816973badee/pyjpboatrace-0.3.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-06-01 16:36:55",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "hmasdev",
"github_project": "pyjpboatrace",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "pyjpboatrace"
}