A tiny, secure, URL-friendly, unique string ID generator for Python. Forked from puyuan/py-nanoid.
- Safe. It uses cryptographically strong random APIs and tests distribution of symbols.
- Compact. It uses a larger alphabet than UUID (A-Za-z0-9_-). So ID size was reduced from 36 to 21 symbols.
pip install python-nanoid
The main module uses URL-friendly symbols (A-Za-z0-9_-) and returns an ID with 21 characters (to have a collision probability similar to UUID v4).
from nanoid import generate
generate() # => NDzkGoTCdRcaRyt7GOepg
Symbols -,.()
are not encoded in the URL. If used at the end of a link they could be identified as a punctuation symbol.
If you want to reduce ID length (and increase collisions probability), you can pass the length as an argument.
from nanoid import generate
generate(size=10) # => "IRFa-VaY2b"
Don’t forget to check the safety of your ID length in ID collision probability calculator.
If you want to change the ID's alphabet or length you can use the internal generate module.
from nanoid import generate
generate('1234567890abcdef', 10) # => "4f9zd13a42"
Non-secure API is also available:
from nanoid import non_secure_generate
non_secure_generate('1234567890abcdef', 10)
- ID size calculator to choice smaller ID size depends on your case. nanoid-dictionary with popular alphabets to use with nanoid/generate.
nanoid-dictionary
with popular alphabets to use.
- v2.0.1
- Fork from puyuan/py-nanoid and switch to GitHub Actions
- Remove deprecated zip_safe
Prior to the fork:
- v2.0.0
- Replace ~ to - in default alphabet.
- Add non-secure fast generator.
- Reduce default characters from 22 to 21.
- v0.3.0
- Fix array out of bound error.
- Andrey Sitnik for Nano ID.
- Dair Aidarkhanov for main contribution to v2.0, and adding test cases.
- Aleksandr Zhuravlev for ID collision probability.