文本處理實例

三個腳本文件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)
相關文章
相關標籤/搜索