Язык программирования Python (Сузи) - страница 25

позволяет упростить этот процесс достаточно стандартным способом. Основные сообщения программы пишутся на английском языке. А переводы строк, отмеченных в программе специальным образом, даются в виде отдельных файлов, по одному на каждый язык (или культурную среду). Уточнить нюансы использования >gettext можно по документации к Python.

Поддержка цикла разработки

Модули этого раздела помогают поддерживать документацию, производить регрессионное тестирование, отлаживать и профилировать программы на Python, а также обслуживают распространение готовых программ, создавая среду для конфигурирования и установки пакетов.

В качестве иллюстрации можно предположить, что создается модуль для вычисления простых чисел по алгоритму «решето Эратосфена». Модуль будет находиться в файле >Sieve.py и состоять из одной функции >primes(N), которая в результате своей работы дает все простые (не имеющие натуральных делителей кроме себя и единицы) числа от >2 до >N:

>import sets

>import math

>"""Модуль для вычисления простых чисел от 2 до N """

>def primes(N):

> """Возвращает все простые от 2 до N"""

> sieve = sets.Set(range(2, N))

> for i in range(2, math.sqrt(N)):

>  if i in sieve:

>   sieve -= sets.Set(range(2*i, N, i))

> return sieve

Модуль pdb

Модуль >pdb предоставляет функции отладчика с интерфейсом — командной строкой. Сессия отладки вышеприведенного модуля могла бы быть такой:

>>>> import pdb

>>>> pdb.runcall(Sieve.primes, 100)

>> /home/rnd/workup/intuit–python/examples/Sieve.py(15)primes()

>-> sieve = sets.Set(range(2, N))

>(Pdb) l

>10    import sets

>11    import math

>12    """Модуль для вычисления простых чисел от 2 до N """

>13    def primes(N):

>14     """Возвращает все простые от 2 до N"""

>15 ->  sieve = sets.Set(range(2, N))

>16     for i in range(2, int(math.sqrt(N))):

>17      if i in sieve:

>18       sieve -= sets.Set(range(2*i, N, i))

>19     return sieve

>20

>(Pdb) n

>> /home/rnd/workup/intuit–python/examples/Sieve.py(16)primes()

>-> for i in range(2, int(math.sqrt(N))):

>(Pdb) n

>> /home/rnd/workup/intuit–python/examples/Sieve.py(17)primes()

>-> if i in sieve:

>(Pdb) n

>> /home/rnd/workup/intuit–python/examples/Sieve.py(18)primes()

>-> sieve -= sets.Set(range(2*i, N, i))

>(Pdb) n

>> /home/rnd/workup/intuit–python/examples/Sieve.py(16)primes()

>-> for i in range(2, int(math.sqrt(N))):

>(Pdb) p sieve

>Set([2, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21, 23, 25, 27, 29, 31, 33, 35, 37, 39,

>41, 43, 45, 47, 49, 51, 53, 55, 57, 59, 61, 63, 65, 67, 69, 71, 73, 75, 77, 79,

>81, 83, 85, 87, 89, 91, 93, 95, 97, 99])

>(Pdb) n

>> /home/rnd/workup/intuit–python/examples/Sieve.py(17)primes()