Skip to main content

Powerful way to construct text, HTML, and XML, plus a kick-ass join

Project description

| |travisci| |version| |downloads| |versions| |impls| |wheel| |coverage|

.. |travisci| image:: https://travis-ci.org/jonathaneunice/quoter.svg?branch=master
:alt: Travis CI build status
:target: https://travis-ci.org/jonathaneunice/quoter

.. |version| image:: http://img.shields.io/pypi/v/quoter.svg?style=flat
:alt: PyPI Package latest release
:target: https://pypi.python.org/pypi/quoter

.. |downloads| image:: http://img.shields.io/pypi/dm/quoter.svg?style=flat
:alt: PyPI Package monthly downloads
:target: https://pypi.python.org/pypi/quoter

.. |versions| image:: https://img.shields.io/pypi/pyversions/quoter.svg
:alt: Supported versions
:target: https://pypi.python.org/pypi/quoter

.. |impls| image:: https://img.shields.io/pypi/implementation/quoter.svg
:alt: Supported implementations
:target: https://pypi.python.org/pypi/quoter

.. |wheel| image:: https://img.shields.io/pypi/wheel/quoter.svg
:alt: Wheel packaging support
:target: https://pypi.python.org/pypi/quoter

.. |coverage| image:: https://img.shields.io/badge/test_coverage-100%25-6600CC.svg
:alt: Test line coverage
:target: https://pypi.python.org/pypi/quoter

Usage
=====

::

from quoter import *

print single('this') # 'this'
print double('that') # "that"
print backticks('ls -l') # `ls -l`
print braces('curlycue') # {curlycue}
print braces('curlysue', padding=1)
# { curlysue }

Cute...but way too simple to be useful, right? Read on!

Let's try something more complicated, where the output has to be
intelligently based on context. Here's a taste of quoting some HTML
content::

print html.p("A para", ".focus")
print html.img('.large', src='file.jpg')
print html.br()
print html.comment("content ends here")

Yields::

<p class='focus'>A para</p>
<img class='large' src='file.jpg'>
<br>
<!-- content ends here -->

This goes well beyond "simply wrapping some text with other text." The
output format varies widely, correctly interpreting CSS Selector-based
controls, using void/self-closing elements where needed, and using
specialized markup such as the comment format when needed. The HTML quoter
and its companion XML quoter are competitive in power and simplicity with
bespoke markup-generating packages.

(A similar generator for Markdown is also newly included, though it's a the
"demonsration" rather than "use in production code" stage.)

Finally, ``quoter`` provides a drop-dead simple, highly functional,
``join`` function::

mylist = list("ABCD")
print join(mylist)
print join(mylist, sep=" | ", endcaps=braces)
print join(mylist, sep=" | ", endcaps=braces.but(padding=1))
print and_join(mylist)
print and_join(mylist[:2])
print and_join(mylist[:3])
print and_join(mylist, quoter=double, lastsep=" and ")

Yields::

A, B, C, D
{A | B | C | D}
{ A | B | C | D }
A and B
A, B, and C
A, B, C, and D
"A", "B", "C" and "D"

Which shows a range of separators, separation styles (both Oxford and
non-Oxford commas), endcaps, padding, and individual item quoting. I daresay
you will not find a more flexible or configurable ``join`` function
*anywhere* else, in any programming language, at any price.

And if you like any particular style of formatting, make it your own::

>>> my_join = join.but(sep=" | ", endcaps=braces.but(padding=1))
>>> print my_join(mylist)
{ A | B | C | D }

Now you have a convenient specialized formatter to your own specifications.

See `the rest of the story
at Read the Docs <http://quoter.readthedocs.org/en/latest/>`_.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

quoter-1.6.1.zip (51.5 kB view hashes)

Uploaded Source

quoter-1.6.1.tar.gz (36.2 kB view hashes)

Uploaded Source

Built Distribution

quoter-1.6.1-py2.py3-none-any.whl (16.5 kB view hashes)

Uploaded Python 2 Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page