Skip to main content

A Python API to randomly select quotes from your favorite movie, TV show, video game, or whatever medium suits your fancy.

Project description

Movie Quote Randomizer

Description

Welcome to the Python package no one needed or asked for: Movie Quote Randomizer.

Movie Quote Randomizer provides an API to randomly select quotes from your favorite movie, TV show, video game, or whatever medium suits your fancy. You can then import this package into your project, provide your own JSON quotes database (or use the built-in one if you're lazy), and in just a few lines of Python randomly select a new quote every time.

Why would you want to do this? Honestly I don't really know.

Maybe you have a school project where you are required write a command line tool that prints randomly selected movie quotes to the console. Good news. Install this package and call into it from your main(), and you're done. A+ this semester. You're welcome.

Maybe you want to flatter your boss by having the project you're developing at work periodically print their pearls of "wisdom" in the log files. Happy to help.

Perhaps you work for the government and you need to provide a "business justification" for the most trivial things. Ron Swanson quotes fit the bill here nicely.

Personally, I like the idea of adding an easter egg that, when activated, prints randomly selected dialogue from the long lost E.T. videogame for NES.

Look, how you use this isn't really my problem. That sounds more like a you problem. I've already done the hard work for you.

Installation

You can install this package from PyPI via pip:

pip install movie-quote-randomizer

However, as it's a library that's intended for use from another project, you'll probably want to add movie-quote-randomizer to your project's install_requires.

Usage

Simply import MQRandomizer from mq_randomizer, and instantiate it. If you have your own JSON quote database, use that. Otherwise you'll get quotes from the 1995 Film, Hackers.

The randomizer object returns MQuote objects.

You can work with MQuote objects in three ways:

They are proper Python dictionaries that look like:

{
  'quote_type': 'single',
  'characters': ['Nikon'],
  'lines': [{'Nikon': "You're in the butter zone now, baby."}],
  'media_title': 'Hackers',
  'media_type': 'movie',
  'year': 1995
}

They're Python objects with several useful properties defined:

  • characters: list[str]
  • lines: list[dict[str, str]]
  • media_title: str
  • media_type: str
  • year: int

Also they're easily converted to a string for easy logging/console printing:

In [7]: str(generator.random_quote())
Out[7]: 'Dade Murphy: The pool on the roof must have a leak.'

JSON Structure

Here's an abbreviated JSON dictionary:

{
  "meta": {
    "version": 1,
    "media_title": "Hackers",
    "media_type": "movie",
    "year": 1995,
    "description": "Quotes from the movie Hackers"
  },
  "quotes": [
    {
      "quote_type": "single",
      "characters": [
        "The Plague"
      ],
      "lines": [
        {
          "The Plauge": "The Plague: There is no right and wrong. There's only fun and boring."
        }
      ]
    },
    {
      "quote_type": "dialogue",
      "characters": [
        "Dade Murphy",
        "Mrs. Murphy"
      ],
      "lines": [
        {
          "Dade Murphy": "I'm taking over a TV network."
        },
        {
          "Mrs. Murphy": "Finish up, honey, and get to sleep."
        }
      ]
    }
  ]
}

Note there are two quote types: "single" where there's a single line by a single character, and "dialogue" where there are mutliple lines between two or more characters.

Example

Here's an end-to-end example:

from mq_randomizer import MQRandomizer

def main():
  randomizer = MQRandomizer("path/to/quotes.json")
  quote = randomizer.random_quote()

  print("Media title: "+quote.media_title)
  print("Media type: "+quote.media_type)
  print("Year: "+quote.year)
  for character in quote.characters:
    print(character)

  print(str(quote))

Unattributed Quotes

In some cases the quotes aren't associated with a particular character or even the narrator. Take this from the opening sequence of the video game Zero Wing (1989):

In A.D. 2101

War was beginning.

In this case the "character" should be the special value "__none__" which will tell the MQuote object to not render the character's name.

Here's some JSON:

{
  "meta": {
    "version": 1,
    "media_title": "Zero Wing",
    "media_type": "Video Game",
    "year": 1989,
    "description": "Quotes from the video game Zero Wing, noted for poorly translated subtitles that spawned an internet meme."
  },
  "quotes": [
    {
      "quote_type": "dialogue",
      "characters": [
        "__none__"
      ],
      "lines": [
        { "__none__": "In A.D. 2101" },
        { "__none__": "War was beginning."}
      ]
    },
  ]
}
In [19]: str(q)
Out[19]: 'In A.D. 2101\nWar was beginning.'

In [20]: print(str(q))
In A.D. 2101
War was beginning.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

movie_quote_randomizer-0.1.0b3.tar.gz (8.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

movie_quote_randomizer-0.1.0b3-py3-none-any.whl (9.8 kB view details)

Uploaded Python 3

File details

Details for the file movie_quote_randomizer-0.1.0b3.tar.gz.

File metadata

File hashes

Hashes for movie_quote_randomizer-0.1.0b3.tar.gz
Algorithm Hash digest
SHA256 48b2cf8cd50f5d2195f47f441518503c1374c66c4ebde627c0d0ad0827ca6e73
MD5 44007aa6c242b2297263974171ed36f8
BLAKE2b-256 47d93824633683322317d515a20e6682e711dee4f40c53fa78a926dcc213b5b2

See more details on using hashes here.

File details

Details for the file movie_quote_randomizer-0.1.0b3-py3-none-any.whl.

File metadata

File hashes

Hashes for movie_quote_randomizer-0.1.0b3-py3-none-any.whl
Algorithm Hash digest
SHA256 ce94bbc0e1b713f23bf3c76a344f608146b3e5f12755808c6d5cfe43c273cfda
MD5 52214f91100af1805117702e7ef8a484
BLAKE2b-256 922635b2ede04ab32e7adcddbe01404487bc017cd26c7a093ec29292ff6e0d16

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page