Metadata-Version: 2.1
Name: pyopentdb
Version: 0.0.4
Summary: Python interface for the Open Trivia DB
Home-page: https://github.com/amickael/pyopentdb
Author: Andrew Mickael
Author-email: andrew.mickael@gmail.com
License: MIT
Platform: NT
Platform: POSIX
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: MacOS :: MacOS X
Classifier: Operating System :: POSIX
Classifier: Operating System :: Microsoft :: Windows
Requires-Python: >=3.6
Description-Content-Type: text/markdown
Requires-Dist: requests

[![GitHub issues](https://img.shields.io/github/issues/amickael/pyopentdb)](https://github.com/amickael/pyopentdb/issues)
![PyPI](https://img.shields.io/pypi/v/pyopentdb?color=blue)
![PyPI - Downloads](https://img.shields.io/pypi/dw/pyopentdb?color=red)
[![GitHub license](https://img.shields.io/github/license/amickael/pyopentdb?color=purple)](https://github.com/amickael/pyopentdb/blob/master/LICENSE)
[![Code style](https://img.shields.io/badge/code%20style-black-black)](https://github.com/psf/black)

# pyopentdb
Python interface for the [Open Trivia DB API](https://opentdb.com/api_config.php)

<img src="https://opentdb.com/images/logo.png" height="175">

## 👶 Dependencies
* [Python 3.6 or higher](https://www.python.org/downloads/)

## 🛠️ Installation
Install from PyPI using `pip`, you may need to use `pip3` depending on your installation.
```sh
pip install pyopentdb
```

## 🚀 Quick Start
To get started create an instance of `OpenTDBClient`. Helper enums are provided to make querying easier. Using these enums is not required, you may also pass the standard identifiers as integers/strings. Please see the [API documentation](https://opentdb.com/api_config.php) for more information.



A session token is automatically generated when the object is initialized. The client will also attempt to automatically recycle the token when it expires or runs out of new questions.

Calling `.get_questions()` will return a `QuestionSet` object of `Question` objects. `QuestionSet` is a thin wrapper around a list that provides some additional convenience methods.

```python
from pyopentdb import OpenTDBClient, Category, QuestionType, Difficulty

client = OpenTDBClient()
questions = client.get_questions(
    amount=5,
    category=Category.SCIENCE_NATURE,
    question_type=QuestionType.MULTIPLE,
    difficulty=Difficulty.MEDIUM
)
```

```python
>>> questions
[
  Question(category=<Category.SCIENCE_NATURE: CategoryItem(id=17, name='Science & Nature')>, question_type=<QuestionType.MULTIPLE: 'multiple'>, difficulty=<Difficulty.MEDIUM: 'medium'>, question='All the following metal elements are liquids at or near room temperature EXCEPT:', choices=['Mercury', 'Caesium', 'Gallium', 'Beryllium'], answer='Beryllium', answer_index=3),
  Question(category=<Category.SCIENCE_NATURE: CategoryItem(id=17, name='Science & Nature')>, question_type=<QuestionType.MULTIPLE: 'multiple'>, difficulty=<Difficulty.MEDIUM: 'medium'>, question='The medical condition osteoporosis affects which part of the body?', choices=['Skin', 'Heart', 'Brain', 'Bones'], answer='Bones', answer_index=3),
  Question(category=<Category.SCIENCE_NATURE: CategoryItem(id=17, name='Science & Nature')>, question_type=<QuestionType.MULTIPLE: 'multiple'>, difficulty=<Difficulty.MEDIUM: 'medium'>, question='About how old is Earth?', choices=['4.5 Billion Years', '3.5 Billion Years', '5.5 Billion Years', '2.5 Billion Years'], answer='4.5 Billion Years', answer_index=0),
  Question(category=<Category.SCIENCE_NATURE: CategoryItem(id=17, name='Science & Nature')>, question_type=<QuestionType.MULTIPLE: 'multiple'>, difficulty=<Difficulty.MEDIUM: 'medium'>, question='What do you study if you are studying entomology?', choices=['the Brain', 'Fish', 'Humans', 'Insects'], answer='Insects', answer_index=3),
  Question(category=<Category.SCIENCE_NATURE: CategoryItem(id=17, name='Science & Nature')>, question_type=<QuestionType.MULTIPLE: 'multiple'>, difficulty=<Difficulty.MEDIUM: 'medium'>, question='Which of the following men does not have a chemical element named after him?', choices=['Albert Einstein', 'Enrico Fermi', 'Sir Isaac Newton', 'Niels Bohr'], answer='Sir Isaac Newton', answer_index=2)
]
```

Question choices are shuffled on each call. The `answer_index` field is provided to easily check the correct answer in the choice list.

Both `Question` and `QuestionSet` provide the `.to_serializable` method, which returns either an easily serializable output or a JSON formatted string.

## ⚙️ API Reference

## OpenTDBClient
Client that handles HTTP requests and session tokens

### Methods

#### get_questions
Get a set of questions based on query params

* Parameters:
  * amount: int = 10 : Number of items to return between 1 and 50
  * category: (Category, int) = None : Category enum or ID, None for all
  * difficulty: (Difficulty, str) = None : Difficulty enum or name, None for all
  * question_type: (QuestionType, str) = None : Question type enum or name, None for all
  * retry: int = 5 : Number of times to retry call after 4xx or 5xx status code or nonzero response code

* Returns:
  * QuestionSet

## Question
Represents a single question returned by the API

### Parameters
* category: Category : Category enum
* question_type: QuestionType : Question type enum
* difficulty: Difficulty : Difficulty enum
* question: str : Question string
* choices: List[str] : List of shuffled provided choices
* answer: str : Answer string
* answer_index: int : Index of answer in choices list

### Methods

#### to_serializable
Generate an easily serializable object or JSON formatted string

* Parameters:
  * as_json: bool = False : Return a JSON formatted string

* Returns:
  * (dict, str)

## QuestionSet
Represents an array of questions returned by the API, behaves like a list

### Parameters
* items: List[Question] : Array of Question objects

### Methods

#### to_serializable
Generate an easily serializable object or JSON formatted string

* Parameters:
  * as_json: bool = False : Return a JSON formatted string

* Returns:
  * (List[dict], str)


## ⚖️ License
[MIT © 2020 Andrew Mickael](https://github.com/amickael/pyopentdb/blob/master/LICENSE)


