Skip to content
Ruby like string interpolation #{} in Python
Python
Branch: master
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
interpy
.gitignore
MANIFEST.in
README.md spelling: highly May 12, 2016
README.rst
example.py
interpy.pth First fully working and functional version :) Jan 8, 2014
setup.py Improved setup classifiers. Version updated. Jan 8, 2014

README.md

Interpy = Python String Interpolation

Interpy extends Python to support Ruby like string interpolation #{}. Quick example: print "Hello #{your_name}"

It is highly optimized, and directly compiled to bytecode, so you will have the same Python speed when using it.

Installation

The installation of this package is quite simple, you only have to run pip install interpy.

Usage

All python files with string interpolation must have the following first line

# coding: interpy

Example:

# coding: interpy

package = "Interpy"
print "Enjoy #{package}!"

How it works

This package is inspired by Dropbox's pyxl template engine.

Parsing

Interpy uses support for specifying source code encodings as described in PEP 263 to do what it does. The functionality was originally provided so that python developers could write code in non-ascii languages (eg. chinese variable names). Interpy creates a custom encoding called interpy which allows it to convert interpolated strings into regular python before the file is compiled. Once the interpy codec is registered, any file starting with # coding: interpy is run through the interpy parser before compilation.

Compiling

The above example would be compiled to this (in bytecode):

# coding: interpy

package = "Interpy"
print "Enjoy "+str(package)+"!"

Compatibility

This package is fully compatible with Python 2+, Python 3+ and PyPy

Why?

I really enjoyed Ruby String interpolation, and "".format(...) or "" % (...) seems very verbose to me. I'm lazy by nature ;)

You can’t perform that action at this time.