SQL.py

本文介绍了一个使用Python操作SQLite数据库的具体实例,通过读取文本文件中的数据并将其插入到数据库中,同时展示了如何执行简单的SQL查询来筛选特定条件的数据。
import sqlite3,sys
def convert(value):
    if value.startswith('~'):
        return value.strip('~')
    if not value:
        value='0'
    return float(value)
conn=sqlite3.connect('food.db')
curs=conn.cursor()
curs.execute('''
CREATE TABLE IF NOT EXISTS food(
id      TEXT    PRIMARY KEY,
desc    TEXT,
water   FLOAT,
fat     FLOAT,
fiber   FLOAT,
sugar   FLOAT
)
''')
insert_query='INSERT INTO food VALUES(?,?,?,?,?,?)'
for line in open('ABBREV.txt'):
    fields=line.split('^')
    field_count=len(fields)
    print(fields)
    vals=[convert(f) for f in fields[:field_count]]
    curs.execute(insert_query,vals)
conn.commit()

select_all='SELECT * FROM food'
curs.execute(select_all)
print(curs.fetchall())

select_str='fat<=100 AND fiber>=10 AND sugar ORDER BY sugar'
try:
    if sys.argv[1]: select_str=sys.argv[1]
    print('\n',sys.argv,'\n')
except: pass
#命令行调用,windows下SQL.py要加引号
#python SQL.py 'fat<=100 AND fiber>=10 AND sugar ORDER BY sugar'
print(select_str)
select_query='SELECT * FROM food WHERE %s' % select_str
curs.execute(select_query)
names=[f[0] for f in curs.description]
name=[f for f in curs.description]
print(name)
for row in curs.fetchall():
    for pair in zip(names,row):
        print('%s:%s' % pair)
conn.close()

 

转载于:https://www.cnblogs.com/feifeidxl/p/5617898.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值