No description, website, or topics provided.
Python Roff Makefile
Switch branches/tags
Nothing to show
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Failed to load latest commit information.
debian #10 Apr 9, 2018
usr * usr/bin/python3-petname, usr/bin/python-petname: Apr 28, 2017
LICENSE * cmd/petname/main.go, debian/control, debian/golang-petname- Dec 14, 2014
Makefile * Makefile, petname/, petname/,, Apr 27, 2017 #10 Apr 9, 2018 opening 2.3 Apr 28, 2017 * Makefile, petname/, petname/,, Apr 27, 2017



petname − a utility to generate "pet names", consisting of a random combination of adverbs, an adjective, and an animal name


  • Complete version:
usage: petname [-w|--words INT] [-l|--letters INT] [-s|--separator STR] [-d|--dir STR] [-c|--complexity INT] [-u|--ubuntu]
  • Python version:
usage: petname [-h] [-w WORDS] [-l LETTERS] [-s SEPARATOR]


  • -w|--words number of words in the name, default is 2,
  • -l|--letters maximum number of letters in each word, default is unlimited,
  • -s|--separator string used to separate name words, default is '-',
  • -d|--dir directory containing adverbs.txt, adjectives.txt, names.txt, default is /usr/share/petname/,
  • -c|--complexity [0, 1, 2]; 0 = easy words, 1 = standard words, 2 = complex words, default=1,
  • -u|--ubuntu generate ubuntu-style names, alliteration of first character of each word.


This utility will generate "pet names", consisting of a random combination of an adverb, adjective, and an animal name. These are useful for unique hostnames or container names, for instance.

As such, PetName tries to follow the tenets of Zooko’s triangle. Names are:

  • human meaningful
  • decentralized
  • secure


$ petname

$ petname --words 1

$ petname --words 3

$ petname --words 4

$ petname --separator ":"

$ petname --separator "" --words 3

$ petname --ubuntu

$ petname --complexity 0


Besides this shell utility, there are also native libraries: python-petname, python3-petname, and golang-petname. Here are some programmatic examples in code:

Golang Example

Install it with apt:

$ sudo apt-get install golang-petname
package main

import (

var (
	words = flag.Int("words", 2, "The number of words in the pet name")
	separator = flag.String("separator", "-", "The separator between words in the pet name")

func main() {
	fmt.Println(petname.Generate(\*words, \*separator))

Python Example

See: on pypi.

Install it with pip:

$ [sudo] pip install petname
import argparse
import petname

parser = argparse.ArgumentParser(description="Generate human readable random names")
parser.add_argument("-w", "--words", help="Number of words in name, default=2", default=2)
parser.add_argument("-s", "--separator", help="Separator between words, default='-'", default="-")
parser.options = parser.parse_args()

print(petname.Generate(int(parser.options.words), parser.options.separator))


This manpage and the utility were written by Dustin Kirkland <> for Ubuntu systems (but may be used by others). Permission is granted to copy, distribute and/or modify this document and the utility under the terms of the Apache2 License.

The complete text of the Apache2 License can be found in /usr/share/common-licenses/Apache-2.0 on Debian/Ubuntu systems.