2012-04-24 4 views
0

많은 열거 형 테이블과 필드가 있습니다.manage.py inspectdb and enums

transit enum('yes','no') default 'no'과 같이 MySQL에서 열거 형을 검사 할 수 있습니까? 기본적으로 작동하지 않습니다. > IPADDR = models.CharField (MAX_LENGTH = 45)

답변

0

이이 작업에 대한 기본 방법은 없습니다, 또는 anwsering에 대한 내 질문이 너무 바보 같은 것 같다 - ipaddr varchar(15) NOT NULL default '', :

또한 내가 잘못된 문자 길이 정의를 가지고있다. 그래서, 나 자신의 자전거를 만들었 어 :) 그 코드가 작동하는 것처럼 보이지만 잘 테스트하지 않았다.

#!/usr/bin/python 

import re, MySQLdb 
from MySQLdb import cursors 
from settings import DATABASES 

DB_SETUP = { 
    'host':  DATABASES['default']['HOST'] or 'localhost', 
    'user':  DATABASES['default']['USER'] or 'root', 
    'passwd': DATABASES['default']['PASSWORD'] or 'None', 
    'db':  DATABASES['default']['NAME'] or 'mysql', 
    'charset': 'utf8', 
    } 

db = MySQLdb.connect(cursorclass=cursors.DictCursor, **DB_SETUP) 
cursor = db.cursor() 

def max_len(str): 
    return max([ len(i.strip().replace("'", '')) for i in str.split(',') ]) 

def get_enum_tuple(string): 
    return tuple((i.strip().replace("'", ''), i.strip().replace("'", '')) for i in string.split(',')) 

patterns = { 
    re.compile(r'enum\((?P<choices>[\'|\w|,*|\s*]+)\)', re.IGNORECASE): 
     'models.CharField', 
    re.compile(r'varchar\((?P<max_length>\d+)\)', re.IGNORECASE): 
     'models.CharField', 
    re.compile(r'char\((?P<max_length>\d+)\)', re.IGNORECASE): 
     'models.CharField', 
    re.compile(r'int\((?P<max_length>\d+)\)', re.IGNORECASE): 
     'models.IntegerField', 
    re.compile(r'tinyint\((?P<max_length>\d+)\)', re.IGNORECASE): 
     'models.IntegerField', 
    re.compile(r'datetime', re.IGNORECASE): 
     'models.DateTimeField', 
} 

def table_classname(table): 
    words = [ w.capitalize() for w in table.split('_') ] 
    return ''.join(words) 

cursor.execute('SHOW TABLES') 
for table in [ i.values()[0] for i in cursor.fetchall() ]: 
    cursor.execute('DESCRIBE `%s`' % table) 

    class_model = [] 
    for row in cursor.fetchall(): 
     args = [] 
     if row['Null'] == 'YES':  args.append('blank=True') 
     if row['Default']:    args.append("default='%s'" % row['Default']) 
     if row['Key'] == 'PRI':   args.append('primary_key=True') 
     if row['Key'] == 'UNI':   args.append('unique=True') 

     if '-' in row['Field']: 
      args.append("db_column='%s'" % row['Field']) 
      row['Field'] = row['Field'].replace('-', '_') 

     field_type = None 
     for pat in patterns: 
      m = pat.match(row['Type']) 
      if m: 
       d = m.groupdict() 
       if 'choices' in d: 
        args.append('max_length=%s' % max_len(d['choices'])) 
        args.append('choices=%s' % str(get_enum_tuple(d['choices']))) 
        del d['choices'] 

       if d: 
        for k in d: 
         args.append('%s=%s' % (k, d[k])) 

       field_type = patterns[pat] 
       break 

     args = ', '.join(args) 
     class_model.append('{field} = {field_type}({args})'.format(field=row['Field'], field_type=field_type, args=args)) 

    print 'class %s(models.Model):' % table_classname(table) 
    for s in class_model: 
     print '\t%s' % s 

    print '\n\tclass Meta:' 
    print "\t\tdb_table = '%s'\n" % table