Skip to main content

Easy Markov chain text generator.

Project description

Markovchatter

Easy Markov chain text generator. (CLI / Web API)

Install

pip install markovchatter

This installs The markovchatter Python module and the markovchatter command line program. You can run the program like both

$ python3 -m markovchatter ...

and

$ markovchatter ...

Usage

Use as a command

usage: markovchatter run [-h] [-l] [-d] file [file ...]

positional arguments:
  file              text file(s) to learn

options:
  -h, --help        show this help message and exit
  -l, --new-line    files are in new-line text format
  -d, --no-divider  join words without spaces

Example:

$ markovchatter run source.txt
Enim ut sem nulla pharetra diam sit amet risus nullam eget felis eget nunc scelerisque viverra.

(Of course, the output text is depends on your source.)

Run as a Web API server

usage: markovchatter.py server [-h] [-l] [-d] [-p PORT] file [file ...]

positional arguments:
  file                  text file(s) to learn

options:
  -h, --help            show this help message and exit
  -l, --new-line        files are in new-line text format
  -d, --no-divider      join words without spaces
  -p PORT, --port PORT  listen port number [5000]

Start the server:

$ markovchatter server source.txt
 * Running on http://127.0.0.1:5000
Press CTRL+C to quit

And send GET request to http://hostname:port/text in another terminal:

$ curl http://localhost:5000/text
Cursus sit amet consectetur adipiscing elit ut aliquam purus sit amet nisl suscipit adipiscing bibendum est.

(The response text is depends on your source, again.)

Options details

Files

The files given to the program is the source text file, which contain sentences it uses as the model. They are normally well-punctuationed text which terminates its sentence with a dot ('.').

If your source text is not suitable for the style; e.g. languages doesn't use dots for its period, you can use new-line format text file with --new-line option. See option details bellow.

-l, --new-line

If this option is set, given files are treated as new-line formatted text; which has each sentence on a newline. This is suitable for languages that doesn't use dot (".") for its sentence period.

The feature comes from a library implementation:

Markovify works best with large, well-punctuated texts. If your text does not use .s to delineate sentences, put each sentence on a newline, and use the markovify.NewlineText class instead of markovify.Text class.

jsvine/markovify: A simple, extensible Markov chain generator.

When the option is set, marcovchatter uses markovify.NewlineText class instead of markovify.Text as described above.

-d, --no-divider

The markovify library suppose languages that separate words with spaces, and its output is in the same way too. This is annoying when the language doesn't use spaces for its word divider. When the option is set, markovchatter joins words without spaces; which is more suitable for languages like Japanese.

License

MIT. See LICENSE.

Thanks

This tool uses markovify by Jeremy Singer-Vine and Flask by Armin Ronacher. Thank you for these libraries and its developers.

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

markovchatter-1.0.tar.gz (4.4 kB view details)

Uploaded Source

Built Distribution

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

markovchatter-1.0-py3-none-any.whl (4.8 kB view details)

Uploaded Python 3

File details

Details for the file markovchatter-1.0.tar.gz.

File metadata

  • Download URL: markovchatter-1.0.tar.gz
  • Upload date:
  • Size: 4.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.6

File hashes

Hashes for markovchatter-1.0.tar.gz
Algorithm Hash digest
SHA256 c7eff7b37432ff8741dfac03d0d3ee7eaaada3591561915ef7c7c1af96280ea5
MD5 70e048f81287a193272d7e5119d78aad
BLAKE2b-256 1315729f28579798ab429cb8fffae3d865b57dd0057aed866ab7b8402e73e230

See more details on using hashes here.

File details

Details for the file markovchatter-1.0-py3-none-any.whl.

File metadata

  • Download URL: markovchatter-1.0-py3-none-any.whl
  • Upload date:
  • Size: 4.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.6

File hashes

Hashes for markovchatter-1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 cac27b8ea363e87bc9cb3493f55e8b8f6559dc592342afdfb2373a4157f9bc0a
MD5 3dca1df6fa766aa577b3b9483d5d3ede
BLAKE2b-256 a38c75d186b1aeb128a17fd31390835fcd3387a09e991eb0e553d6df5d6c07cb

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