Ich habe in dieser Zeit den gleichen regulären Ausdruck geschrieben und verstehe nicht, warum es nicht funktioniert hat.
remultiline.py
# -*- coding:utf-8 -*-
import re
text = """
[id][integer] PRIMARY KEY,
[column1][varchar](10) NOT NULL UNIQUE,
[column2][datetime] NULL,
[column3][decimal](10,2) NOT NULL
"""
pattern = r'^\[([^\]]+)\]\[([^\]]+)\](\([^\)]+\))?\s.+$'
#Ohne das MULTILINE-Flag wird es nicht korrekt verarbeitet.
print "with re.M", re.findall(pattern, text, re.M)
#=> [('id', 'integer', ''),
# ('column1', 'varchar', '(10)'),
# ('column2', 'datetime', ''),
# ('column3', 'decimal', '(10,2)')]
print "without re.M", re.findall(pattern, text)
# => []