三個腳本文件mysql
①、建立表sql
#建立表
from sqlalchemy import Column, MetaData, Table
from sqlalchemy import Integer
from sqlalchemy import String
from sqlalchemy import create_engine
engine = create_engine('mysql+pymysql://jiang:123456@192.168.137.130/data')
metadata = MetaData(engine)
dictionary = Table('dictionary', metadata,
Column('id', Integer, primary_key=True),
Column('key', String(50)),
Column('value', String(50))
)
student = Table('student', metadata,
Column('id', Integer, primary_key=True),
Column('name', String(20)),
Column('gender', String(2)),
Column('age', String(5))
)
metadata.create_all(engine)
②、將處理完的數據插入表中session
#在表中插入數據
import codecs
from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker
engine = create_engine('mysql+pymysql://jiang:123456@192.168.137.130:3306/data?charset=utf8')
DBSession = sessionmaker(bind=engine)
session = DBSession()
Base = declarative_base()
class InsertDatas(Base):
__tablename__= 'dictionary'
__table_args__ = {
'mysql_engine': 'InnoDB', #選擇InnoDB格式
'mysql_charset': 'utf8mb4' #選擇utf8格式
}
id = Column(Integer, primary_key=True)
key = Column(String(50))
value = Column(String(50))
#處理數據並插入表中
class OptDate(object):
def __init__(self, datafile):
self.datafile = datafile
def makedatatostr(self):
with codecs.open("dictionary.txt", encoding='utf-8') as file:
for (num, value) in enumerate(file):
line = value.strip().split()
diction = InsertDatas(id=num+1, key=line[0], value=line[1])
session.add(diction)
session.commit()
if __name__ == '__main__':
optdate = OptDate("dictionary.txt")
optdate.makedatatostr()
session.close()
③、查詢表中的數據spa
#查詢數據
from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker
engine = create_engine('mysql+pymysql://jiang:123456@192.168.137.130:3306/data?charset=utf8')
DBSession = sessionmaker(bind=engine)
session = DBSession()
Base = declarative_base()
class InsertDatas(Base):
__tablename__= 'dictionary'
id = Column(Integer, primary_key=True)
key = Column(String(50))
value = Column(String(50))
a = session.query(InsertDatas).filter(InsertDatas.id<10).all()
for i in a:
print(i.id)
print(i.key)
print(i.value)word = input("please input your a word:")
result =session.query(InsertDatas).filter(InsertDatas.key.like("%{0}%".format(word))).all() #查詢和輸入有關的詞
for each in result:
print(each.id, each.key, each.value)