Упаковка библиотеки Python - PullRequest
4 голосов
/ 28 ноября 2008

У меня есть несколько плагинов Munin, которые сообщают статистику из базы данных автономии. Все они используют небольшую библиотеку, которая очищает вывод статуса XML для соответствующих чисел.

Я пытаюсь связать библиотеку и плагины в RPM, устанавливаемый Puppet. Фактическое построение RPM должно быть простым; когда у меня есть дистрибутив distutils, я могу превратить его в RPM на основе файла .spec, сжатого из репозиториев Dag или EPEL [1]. Это бит distutils, в котором я не уверен - на самом деле я даже не уверен, что моя библиотека правильно написана для упаковки. Вот как это работает:

idol7stats.py:

import datetime
import os
import stat
import sys
import time
import urllib
import xml.sax

class IDOL7Stats:
  cache_dir = '/tmp'

  def __init__(self, host, port):
    self.host = host
    self.port = port

  # ...

  def collect(self):
    self.data = self.__parseXML(self.__getXML())

  def total_slots(self):
    return self.data['Service:Documents:TotalSlots']

Код плагина:

from idol7stats import IDOL7Stats
a = IDOL7Stats('db.example.com', 23113)
a.collect()
print a.total_slots()

Думаю, я хочу, чтобы idol7stats.py попал в /usr/lib/python2.4/site-packages/idol7stats или что-то еще в пути поиска Python. Какая магия distutils мне нужна? Это:

from distutils.core import setup

setup(name = 'idol7stats',
  author = 'Me',
  author_email = 'me@example.com',
  version = '0.1',
  py_modules = ['idol7stats'])

почти работает, за исключением того, что код идет в /usr/lib/python2.4/site-packages/idol7stats.py, а не в подкаталог. Я ожидаю, что это из-за того, что я не понимаю разницу между модулями / пакетами / другими контейнерами в Python.

Так в чем же проблема?

[1] Да, я мог бы просто подключить библиотеку в /usr/lib/python2.4/site-packages, используя RPM, но я хочу знать, как упаковать код Python.

1 Ответ

2 голосов
/ 28 ноября 2008

Вам нужно создать пакет , чтобы делать то, что вы хотите. Вам понадобится каталог с именем idol7stats, содержащий файл с именем __init__.py и любые другие библиотечные модули для упаковки. Кроме того, это повлияет на импорт ваших скриптов; если вы поместите idol7stats.py в пакет с именем idol7stats, то ваши сценарии должны будут "import idol7stats.idol7stats".

Чтобы избежать этого, вы можете просто переименовать idol7stats.py в idol7stats/__init__.py, или вы можете поместить эту строку в idol7stats/__init__.py, чтобы «массировать» импорт так, как вы ожидаете:

from idol7stats.idol7stats import *
...