Footnotes in ReST

Peter Otten __peter__ at web.de
Sun Oct 4 06:14:16 EDT 2015


Peter Otten wrote:

> Changing numbers to make room for a new footnote is not much harder (but
> less convenient as you have to repeat it for every new footnote):
> 
>>>> def replace(match, n=2):
> ...     index = int(match.group(1))
> ...     if index >= n:
> ...         index += 1
> ...     return "[{}]".format(index)
> ...
>>>> print(re.compile(r"\[(\d+)\]").sub(replace, text))
>     blah blah blah [1]_ and blah blah blah [3]_.
>     blah blah [4]_ blah ... blah blah
>     blah blah [1000]_.
> 
>     .. [1] fe
>     .. [3] fi
>     .. [4] fo
>        ...
>     .. [1000] fum

Those who remember the old basic dialects might [1]_ like

$ cat insert_footnote_basic.py
#!/usr/bin/env python3
import re
import sys


def step(start, delta):
    n = start
    while True:
        yield n
        n += delta


def insert_footnote(text):
    lookup = {}
    steps = step(10, 10)

    def replace(match):
        index = int(match.group(1))
        try:
            new_index = lookup[index]
        except KeyError:
            new_index = lookup[index] = next(steps)

        return "[{}]".format(new_index)

    return re.compile(r"\[(\d+)\]").sub(replace, text)


if __name__ == "__main__":
    sys.stdout.write(
        insert_footnote(sys.stdin.read())
    )
$ cat sample.rst
blah blah blah [10]_ and blah blah blah [20]_.
[21] this is new
blah blah [30]_ blah ... blah blah
blah blah [9990]_.

.. [10] fe
.. [20] fi
.. [21] yes it is
.. [30] fo
   ...
.. [9990] fum

$ ./insert_footnote_basic.py < sample.rst
blah blah blah [10]_ and blah blah blah [20]_.
[30] this is new
blah blah [40]_ blah ... blah blah
blah blah [50]_.

.. [10] fe
.. [20] fi
.. [30] yes it is
.. [40] fo
   ...
.. [50] fum

$

.. [1] or run away screaming ;)






More information about the Python-list mailing list