Skip to main content

Typio: Make Your Terminal Type Like a Human

Project description

Typio: Make Your Terminal Type Like a Human


built with Python3 GitHub repo size PyPI version

Overview

Typio is a lightweight Python library that prints text to the terminal as if it were being typed by a human. It supports multiple typing modes (character, word, line, sentence, typewriter, and adaptive), configurable delays and jitter for natural variation, and seamless integration with existing code via a simple function or a decorator. Typio is designed to be minimal, extensible, and safe, making it ideal for demos, CLIs, tutorials, and storytelling in the terminal.

PyPI Counter
Github Stars
Branch main dev
CI
Code Quality CodeFactor

Installation

Source Code

PyPI

Usage

Function

Use type_print function to print text with human-like typing effects. You can control the typing speed, randomness, mode, and output stream.

Example

from typio import type_print
from typio import TypeMode

type_print("Hello, world!")

type_print(
    "Typing with style and personality.",
    delay=0.06,
    jitter=0.02,
	end="\n",
    mode=TypeMode.ADAPTIVE,
)

You can also redirect the output to any file-like object:

with open("output.txt", "w") as file:
    type_print("Saved with typing effects.", file=file)

Parameters

Name Type Description
text str Text to be printed
delay float Base delay (seconds) between emitted units
jitter float Random delay variation (seconds)
mode TypeMode | Callable Typing mode (built-in or custom)
file TextIOBase | None Output stream (defaults to sys.stdout)

Built-in Modes

Mode Description
TypeMode.CHAR Emit text character by character
TypeMode.WORD Emit text word by word, preserving whitespace
TypeMode.LINE Emit text line by line
TypeMode.SENTENCE Emit text character by character with longer pauses after ., !, ?
TypeMode.TYPEWRITER Emit text character by character with longer pauses after newlines
TypeMode.ADAPTIVE Emit text with adaptive delays based on character type (spaces, punctuation, alphanumeric)

Decorator

Use the @typestyle decorator to apply typing effects to all print calls inside a function, without changing the function's implementation.

Example

from typio import typestyle
from typio import TypeMode

@typestyle(delay=0.05, mode=TypeMode.TYPEWRITER)
def intro():
    print("Welcome to Typio.")
    print("Every print is typed.")

intro()

Parameters

Name Type Description
delay float Base delay (seconds) between emitted units
jitter float Random delay variation (seconds)
mode TypeMode | Callable Typing mode (built-in or custom)

Custom Mode

Typio also allows defining custom typing modes.

A custom mode is a callable that receives a typing context and the text being printed.

Example

This custom mode, named dramatic, adds exaggerated pauses after punctuation to create a dramatic typing effect.

from typio import TypioContext

def dramatic(ctx: TypioContext, text: str):
    for ch in text:
        ctx.emit(ch)
        if ch in ".!?":
            ctx.sleep(delay=ctx.delay * 6)

Usage with type_print function:

type_print(
    "Wait... what?!",
    mode=dramatic,
    delay=0.05,
    jitter=0.02,
)

Usage with @typestyle decorator:

@typestyle(delay=0.06, mode=dramatic)
def demo():
    print("This is serious.")
    print("Very serious!")

demo()

Parameters

This table describes the TypioContext API, which is the interface exposed to custom typing modes for emitting text, controlling timing, and accessing delay settings.

Name Type Description
emit(text) method Emit a text fragment using typing effects
sleep(delay=None, jitter=None) method Pause execution with optional delay and jitter override
flush() method Flush the underlying output stream
delay property Base delay in seconds
jitter property Jitter value in seconds

Issues & Bug Reports

Just fill an issue and describe it. We'll check it ASAP!

  • Please complete the issue template

Show Your Support

Star This Repo

Give a ⭐️ if this project helped you!

Donate to Our Project

Bitcoin

1KtNLEEeUbTEK9PdN6Ya3ZAKXaqoKUuxCy

Ethereum

0xcD4Db18B6664A9662123D4307B074aE968535388

Litecoin

Ldnz5gMcEeV8BAdsyf8FstWDC6uyYR6pgZ

Doge

DDUnKpFQbBqLpFVZ9DfuVysBdr249HxVDh

Tron

TCZxzPZLcJHr2qR3uPUB1tXB6L3FDSSAx7

Ripple

rN7ZuRG7HDGHR5nof8nu5LrsbmSB61V1qq

Binance Coin

bnb1zglwcf0ac3d0s2f6ck5kgwvcru4tlctt4p5qef

Tether

0xcD4Db18B6664A9662123D4307B074aE968535388

Dash

Xd3Yn2qZJ7VE8nbKw2fS98aLxR5M6WUU3s

Stellar

GALPOLPISRHIYHLQER2TLJRGUSZH52RYDK6C3HIU4PSMNAV65Q36EGNL

Zilliqa

zil1knmz8zj88cf0exr2ry7nav9elehxfcgqu3c5e5

Coffeete

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog and this project adheres to Semantic Versioning.

Unreleased

0.3 - 2026-02-11

Added

  • TypioContext class

Changed

  • Test system modified
  • README.md updated
  • _TypioPrinter class all attributes changed to private
  • _emit method modified
  • _sleep function modified

0.2 - 2026-02-04

Changed

  • README.md updated
  • end parameter added to type_print function
  • Test system modified

0.1 - 2026-01-31

Added

  • type_print function
  • typestyle decorator
  • CHAR mode
  • WORD mode
  • LINE mode
  • SENTENCE mode
  • TYPEWRITER mode
  • ADAPTIVE mode

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

typio-0.3.tar.gz (13.8 kB view details)

Uploaded Source

Built Distribution

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

typio-0.3-py3-none-any.whl (9.5 kB view details)

Uploaded Python 3

File details

Details for the file typio-0.3.tar.gz.

File metadata

  • Download URL: typio-0.3.tar.gz
  • Upload date:
  • Size: 13.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for typio-0.3.tar.gz
Algorithm Hash digest
SHA256 37a6fd255715313bd01691f52cd0adeb4b7c48cfb9f6599009d37f27b61b9189
MD5 c25c9597d3af5d3d4fa86e89bbf97aaa
BLAKE2b-256 d1a2fde9f2aba330f9d9f82e0db56d5d18fee2d1edb5ef3b83de142744f1f95c

See more details on using hashes here.

File details

Details for the file typio-0.3-py3-none-any.whl.

File metadata

  • Download URL: typio-0.3-py3-none-any.whl
  • Upload date:
  • Size: 9.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for typio-0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 65286816dc66d5dfe24034b4789d3aca053147d8230ca5d8236c0c553bfd0dfe
MD5 aafb7315073680aa3a31134fb830f39e
BLAKE2b-256 f72c522d32337a41bf6c1d412fac5dd089563641fb3a8e1efb0612c4b99c08a1

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