Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nomnoms12/saucenao_api
Wrapper for SauceNAO JSON API
https://github.com/nomnoms12/saucenao_api
python python-api-wrapper saucenao saucenao-api
Last synced: 4 months ago
JSON representation
Wrapper for SauceNAO JSON API
- Host: GitHub
- URL: https://github.com/nomnoms12/saucenao_api
- Owner: nomnoms12
- License: gpl-3.0
- Created: 2020-05-19T18:32:35.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2023-06-29T15:29:04.000Z (over 1 year ago)
- Last Synced: 2024-03-15T02:46:55.226Z (11 months ago)
- Topics: python, python-api-wrapper, saucenao, saucenao-api
- Language: Python
- Homepage: https://pypi.org/project/saucenao-api
- Size: 113 KB
- Stars: 64
- Watchers: 2
- Forks: 13
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README

# saucenao_api
[](https://github.com/nomnoms12/saucenao_api/actions?query=workflow%3ATests)
[](https://codecov.io/gh/nomnoms12/saucenao_api)
[](https://github.com/nomnoms12/saucenao_api/blob/master/LICENSE)
[](https://saucenao.com)
[](https://pypi.org/project/saucenao-api)> “The rough edges are a part of its charm”
Unofficial wrapper for the [SauceNAO](https://saucenao.com) JSON API
# Installation
This package requires Python 3.6 or later.
```
pip install -U saucenao_api
```# Usage
```python
from saucenao_api import SauceNao# Replace the key with your own
sauce = SauceNao('077f16b38a2452401790540f41246c7d951330c0')
results = sauce.from_url('https://i.imgur.com/oZjCxGo.jpg') # or from_file()best = results[0] # results sorted by similarity
```The library attempts to provide a developer friendly container format for all results. Meaning, no matter if SauceNao returns a Pixiv source result or a more obscure source, you'll be able to easily pull the `title`, `urls`, `author` and other useful information:
```python
from saucenao_api import SauceNao
results = SauceNao('077f16b38a2452401790540f41246c7d951330c0').from_url('https://i.imgur.com/oZjCxGo.jpg')len(results) # 6
bool(results) # True# Request limits
results.short_remaining # 4 (per 30 seconds limit)
results.long_remaining # 99 (per day limit)results[0].thumbnail # temporary URL for picture preview
results[0].similarity # 93.3
results[0].title # めぐみん
results[0].urls # ['https://www.pixiv.net/member_illust.php?mode=medium&illust_id=77630170']
results[0].author # frgs
results[0].raw # raw result
```Video search results and book search results provide additional attributes:
```python
from saucenao_api import SauceNao, VideoSauce, BookSauce
result = SauceNao('077f16b38a2452401790540f41246c7d951330c0').from_url('https://i.imgur.com/k9xlw6f.jpg')[0]if isinstance(result, VideoSauce):
result.part # 02
result.year # 2009-2009
result.est_time # 00:05:32 / 00:21:10elif isinstance(result, BookSauce):
result.part
```
*You can use the `dir` function to see all the attributes.*## Asyncio
```python
import asyncio
from saucenao_api import AIOSauceNaoasync def main():
# async requesting is also supported via the AIOSauceNao class
async with AIOSauceNao('077f16b38a2452401790540f41246c7d951330c0') as aio:
results = await aio.from_url('https://i.imgur.com/k9xlw6f.jpg')
asyncio.run(main())
```
The async with functionality is pretty useful if you want to make multiple requests.
Note that you can still search without the `async with` syntax by simply calling `await AIOSauceNao(...).from_url(...)`.## Advanced usage
```python
from saucenao_api import SauceNao
from saucenao_api.params import DB, Hide, BgColorsauce = SauceNao(api_key=None, # Optional[str]
testmode=0, # int
dbmask=None, # Optional[int]
dbmaski=None, # Optional[int]
db=DB.ALL, # int
numres=6, # int
frame=1, # int
hide=Hide.NONE, # int
bgcolor=BgColor.NONE, # int
)
```
The parameters `frame`, `hide` and `bgcolor` are taken from the main page and from the [testing page](https://saucenao.com/testing), so their performance is not guaranteed. For the rest see [SauceNAO User Config](https://saucenao.com/user.php?page=search-api) page (registration required).### Exceptions
All exceptions inherit from `SauceNaoApiError` for easy catching and handling. See [`errors.py`](saucenao_api/errors.py) file for details.*Note: SauceNao doesn't have good documentation. Exceptions are created only based on observations of changes in the returned status codes. If you find a specific error that is not being processed, please report it.*
# License
This package is based on [`pysaucenao`](https://github.com/FujiMakoto/pysaucenao).