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

AltStyle によって変換されたページ (->オリジナル) /