the OBSCENE string generation one-liner
Project description
The purpose of the mapjoin function is to have an alternative to str.join that looks more like os.path.join (which takes *args).
Usage:
from mapjoin import mapjoin
mapjoin('foo', 2) # return 'foo 2'
mapjoin('foo', 2, sep='_') # return 'foo_2'
# you can also make mapjoin use your own callback with the key kwarg:
your_formatter = lambda key: str(key) if key else 'Nothin!'
mapjoin('foo', obj, 2, None, sep='\n', key=your_formatter)
But … why ?
Initially, because I make to many mistakes when I write an os.path.join call and then a str.join call in a row:
>>> os.path.join('a', 'b')
'a/b'
# and 2 seconds later i'm doing this:
>>> ' '.join('a', 'b')
TypeError: join() takes exactly one argument (2 given)
# and instead of "just fixit and move on", i decided have a take on join
But also because I can’t get no satisfaction with my code when it looks like:
readable = ' '.join(map(str, [
'hello',
f'__{name}__',
something,
]))
# or:
def foo():
readable = textwrap.dedent(f'''
hello
__{name}__
''').strip()
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
mapjoin-0.0.3.dev1.tar.gz
(1.7 kB
view hashes)