Formatting and EncodingΒΆ
The Devil, as they say, is in the details. We often don’t just want quote
marks wrapped around values. We also want those values set apart from
the rest of the text. quoter
supports this with padding
and margin
settings patterned on the CSS box model.
In CSS, moving out from content one finds padding, a border, and then a margin.
Padding can be thought of as an internal margin, and
the prefix and suffix strings like the border. With that in mind:
print braces('this') # '{this}'
print braces('this', padding=1) # '{ this }'
print braces('this', margin=1) # ' {this} '
print braces('this', padding=1, margin=1) # ' { this } '
If desired, the padding
and margin
can be given explicitly, as
strings. If given as integers, they are interpreted as a
number of spaces.
One can also define the encoding
used for each call, per instance, or
globally. If some of your quote symbols use Unicode characters, yet your output
medium doesn’t support them directly, this is an easy fix. E.g.:
Quoter.options.encoding = 'utf-8'
print curlydouble('something something')
Now curlydouble
will output UTF-8 bytes. But in general, this is not a
great idea; you should work in Unicode strings in Python, encoding or
decoding only at the time of input and output, not as each piece of content
is constructed.