Working with WaniKani API, login, and Community.
Project description
# How to use WaniKaniTools
The following operations are supported by WaniKaniTools
* API v1 wrapper
* API v2 wrapper, and support for pagination
* Web login using `PhantomJS` and able to both `execute_script()` and `click()` buttons accordingly
Sample working scripts are
* `burnManager.py`
* `WaniKaniTools/database/create.py`
* `example/multiple_readings.py`
## Installation
1. For Mac OSX, `brew install phantomjs`. I am not sure about Windows, or other OS's, but you'll need PhantomJS for the web login, burnManager and Community.
2. `pip install WaniKaniTools`
## Using API v1
```python
from WaniKaniTools.api import api
resource = (
'user-information',
'study-queue',
'level-progression',
'srs-distribution',
'recent-unlocks', # Argument is output limit in range 1-100. Default=10
'critical-items', # Argument is percentage in range 0-100. Default=75
'radicals', # Argument is level, comma-delimited. Default=all levels
'kanji',
'vocabulary'
)
api_v1 = api.v1(put_your_api_v1_key_here)
result = api_v1.GET(resource[2])['requested_information'] # Output is Python dictionary
```
## Using API v2
### Basic operations
```python
from WaniKaniTools.api import api
resource_v2 = (
'user',
'subjects', # Argument is id. Params are ids, types, slugs, levels, updated_after
'assignments', # Argument is id. Params are ...
'review_statistics',
'study_materials',
'summary',
'reviews',
'level_progressions',
'resets'
)
api_v2 = api.v2(put_your_api_v2_key_here)
result = api_v2.GET(resource_v2[1]) # Output is Python dictionary
```
### Pagination
```python
from WaniKaniTools.api import api
api_v2 = api.v2(put_your_api_v2_key_here)
result = api_v2.GET('subjects')
while True:
for data in result['data']:
meaning_array = []
for meaning in data["data"]["meanings"]:
if meaning['primary']:
meaning_array += [ meaning['meaning'] ]
to_print = (
data["id"],
data["object"],
data["data"]["characters"] if "characters" in data["data"] else data["data"]["character"],
', '.join(meaning_array),
data["data"]["document_url"]
)
print(*to_print)
next_url = result['pages']['next_url']
if next_url is None:
break
result = api_v2.GETurl(next_url)
```
## Simulating web login
### Web login and execute script
The operations supported here are the same as `selenium-webdriver`
```python
from WaniKaniTools.website import login
with login.Webdriver(your_username, your_password) as w:
w.driver.execute_script(put_your_javascript_here)
```
The following operations are supported by WaniKaniTools
* API v1 wrapper
* API v2 wrapper, and support for pagination
* Web login using `PhantomJS` and able to both `execute_script()` and `click()` buttons accordingly
Sample working scripts are
* `burnManager.py`
* `WaniKaniTools/database/create.py`
* `example/multiple_readings.py`
## Installation
1. For Mac OSX, `brew install phantomjs`. I am not sure about Windows, or other OS's, but you'll need PhantomJS for the web login, burnManager and Community.
2. `pip install WaniKaniTools`
## Using API v1
```python
from WaniKaniTools.api import api
resource = (
'user-information',
'study-queue',
'level-progression',
'srs-distribution',
'recent-unlocks', # Argument is output limit in range 1-100. Default=10
'critical-items', # Argument is percentage in range 0-100. Default=75
'radicals', # Argument is level, comma-delimited. Default=all levels
'kanji',
'vocabulary'
)
api_v1 = api.v1(put_your_api_v1_key_here)
result = api_v1.GET(resource[2])['requested_information'] # Output is Python dictionary
```
## Using API v2
### Basic operations
```python
from WaniKaniTools.api import api
resource_v2 = (
'user',
'subjects', # Argument is id. Params are ids, types, slugs, levels, updated_after
'assignments', # Argument is id. Params are ...
'review_statistics',
'study_materials',
'summary',
'reviews',
'level_progressions',
'resets'
)
api_v2 = api.v2(put_your_api_v2_key_here)
result = api_v2.GET(resource_v2[1]) # Output is Python dictionary
```
### Pagination
```python
from WaniKaniTools.api import api
api_v2 = api.v2(put_your_api_v2_key_here)
result = api_v2.GET('subjects')
while True:
for data in result['data']:
meaning_array = []
for meaning in data["data"]["meanings"]:
if meaning['primary']:
meaning_array += [ meaning['meaning'] ]
to_print = (
data["id"],
data["object"],
data["data"]["characters"] if "characters" in data["data"] else data["data"]["character"],
', '.join(meaning_array),
data["data"]["document_url"]
)
print(*to_print)
next_url = result['pages']['next_url']
if next_url is None:
break
result = api_v2.GETurl(next_url)
```
## Simulating web login
### Web login and execute script
The operations supported here are the same as `selenium-webdriver`
```python
from WaniKaniTools.website import login
with login.Webdriver(your_username, your_password) as w:
w.driver.execute_script(put_your_javascript_here)
```
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
No source distribution files available for this release.See tutorial on generating distribution archives.
Built Distribution
File details
Details for the file WaniKaniTools-0.2.0-py2.py3-none-any.whl
.
File metadata
- Download URL: WaniKaniTools-0.2.0-py2.py3-none-any.whl
- Upload date:
- Size: 4.8 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ba5b17aa00039bebd6d3f26928663b2fcee0e43ba633d6d349831c117fbf6d02 |
|
MD5 | 97e4e479896d5db1aab6e8e201f0691d |
|
BLAKE2b-256 | f8396b9e2c6e9700867bcd1b7727aecd1259774b2034ac5bfdaa752b1c9fad9c |