Уведомления

Группа в Telegram: @pythonsu

#1 Май 1, 2010 11:09:54

Vasya555
От:
Зарегистрирован: 2010-05-01
Сообщения: 4
Репутация: +  0  -
Профиль   Отправить e-mail  

Веб-интерфейс для базы данных

Вот такой вопрос! Есть справочник телефонных абонентов. Для него делаю веб-интерфейс! В питоне не очень разбираюсь но по примеру получился интерфейс для csv-файла.
Но необходимо подключиться к базе данных mysql, и оттуда брать данные, а не к csv/
Как это делается в питон-файлах?
Подскажите, где необходимо это подключение прописать!?)
По аналогии разобраться могу, а просто из головы взять сложно!)
Код

"""
Web интерфейс
"""

import os
from Cheetah.Template import Template
import cherrypy

class Root:
@staticmethod
def prepare(telephoneDir):
Root.collaborators = list(sorted(telephoneDir.subdivision))
Root.subdivisions = list(sorted(telephoneDir.subdivision.iterSubdivision()))
Root.subdivisions.insert(0, 'все')
Root.telephoneTypes = list(sorted(telephoneDir.telephones.telephoneTypes))
Root.telephoneTypes.insert(0, 'все')
Root.telephoneDir = list(sorted(telephoneDir))

@cherrypy.expose
def index(self, page='0', subdivision='0', collaborator='', number='', telephoneType='0'):
page = int(page)
subdivision = int(subdivision)
telephoneType = int(telephoneType)

if not subdivision:
lambdaSubdivision = lambda rec: True
else:
s = Root.subdivisions[subdivision]
lambdaSubdivision = lambda rec: rec.collaborator in s

if not collaborator:
lambdaCollaborator = lambda rec: True
else:
l = len(collaborator)
lambdaCollaborator = lambda rec: str(rec.collaborator)[0:l] == collaborator

if not number:
lambdaNumber = lambda rec: True
else:
l = len(number)
lambdaNumber = lambda rec: str(rec.telephone.number)[0:l] == number

if not telephoneType:
lambdaTelephoneType = lambda rec: True
else:
t = Root.telephoneTypes[telephoneType]
lambdaTelephoneType = lambda rec: rec.telephone.type == t

root = Template(file=os.path.join(os.curdir, 'index.tmpl'))
root.page = page
root.subdivision = subdivision
root.subdivisions = Root.subdivisions
root.collaborator = collaborator
root.number = number
root.telephoneType = telephoneType
root.telephoneTypes = Root.telephoneTypes
root.telephoneDir = filter(lambda telephone: lambdaSubdivision(telephone) and \
lambdaCollaborator(telephone) and \
lambdaNumber(telephone) and \
lambdaTelephoneType(telephone), Root.telephoneDir)
return str(root)

root = Root()

cherrypy.config.update({
'log.screen': True,
'environment': 'production',
'server.socket_port': 8080,
'server.threadPool':10,
'tools.staticfile.on': False,
'tools.sessions.on': True,
'tools.sessions.timeout': 60,
})

conf = {
'/style.css': {
'tools.staticfile.on': True,
'tools.staticfile.filename': os.path.join(os.getcwd(), 'style.css'),
},
}

def run(telephoneDir):
Root.prepare(telephoneDir)
cherrypy.tree.mount(root, config=conf)
cherrypy.server.quickstart()
cherrypy.engine.start()

if __name__ == '__main__':
import tdcsv
telephoneDir = tdcsv.load()
run(telephoneDir)



Офлайн

#2 Май 1, 2010 22:29:28

Vasya555
От:
Зарегистрирован: 2010-05-01
Сообщения: 4
Репутация: +  0  -
Профиль   Отправить e-mail  

Веб-интерфейс для базы данных

Да, так уже понятнее, Спасибо!)
Но можно тогда вопрос
в чем отличие
import MySQLdb и
import _mysql
как ни странно, толкового ответа не нахожу(((



Офлайн

#3 Май 1, 2010 22:40:13

Vasya555
От:
Зарегистрирован: 2010-05-01
Сообщения: 4
Репутация: +  0  -
Профиль   Отправить e-mail  

Веб-интерфейс для базы данных

ааааааа)))
другой теперь вопрос!) А можно в данном случае прописать доступ к БД в другом файле,
например mydb.py,
а в данном файле сервера только написать вызов этого файла
import mydb.py ??
или это совсем не правильно и нужно опять к библиотеке MySQLdb обращаться?))



Офлайн

#4 Май 1, 2010 23:01:08

Lexander
От:
Зарегистрирован: 2008-09-19
Сообщения: 1139
Репутация: +  33  -
Профиль   Отправить e-mail  

Веб-интерфейс для базы данных

Смотря для чего и какой алгоритм работы предусматривается.
Если вы делаете свою собственную обертку над MySQLdb - это одно (тогда в каждом файле, в котором вы используете эту обертку, импортируйте ее) - но это обычно очень редкий случай,- когда такую обертку нужно делать.
Если речь идет о создании отдельного класса, который вы используете для всех операций с БД вашей программы, то импортируйте модуль с классом, а в файле описания класса используйте MySQLdb.
Во всех прочих случаях нужно импортировать MySQLdb напрямую.

ЗЫ
не нужно указывать расширение при импорте.



Офлайн

#5 Май 1, 2010 23:09:15

Vasya555
От:
Зарегистрирован: 2010-05-01
Сообщения: 4
Репутация: +  0  -
Профиль   Отправить e-mail  

Веб-интерфейс для базы данных

Ах, да, расширение -издержки копирования)))

Спасибо!) Наверное мне как раз необходимо только модуль с классом импортировать)))
Буду пробовать)))



Офлайн

Board footer

Модераторировать

Powered by DjangoBB

Lo-Fi Version