python3生成随机数据,并存入sqlite3
admin
2023-07-25 01:42:41
0
#!/usr/bin/python
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2018/6/15 22:46
# @Author  : Kwan
# @File    : insert_db.py
# @Software: PyCharm

import sqlite3
import random
import datetime

# conn = sqlite3.connect('local.db')
#
# c = conn.cursor()
#
# c.execute("insert into system_cfg values(?,?,?)",(2,'test2',1))
#
# conn.commit()
#
# conn.close()

def make_date():
    # def make_card_number(bits):
    #     counter = bits
        # number_list = []
        # while counter:
        #     number_list.append(str(random.randrange(0, 10)))
        #     counter -= 1
        # return number_list

    number_list = [str(x) for x in range(0, 10)]
    card_number = ''
    card_number = card_number.join(tuple(random.choices(number_list,k=10)))
    # card_number = ''
    # card_number = card_number.join(tuple(make_card_number(10)))
    car_type = random.choice(('m','p'))
    localtime = datetime.date.isoformat(datetime.datetime.now())
    data_title = ['card_number','car_type','localtime']
    data_dict = dict.fromkeys(data_title)
    data_dict['card_number'] = card_number
    data_dict['car_type'] = car_type
    data_dict['localtime'] = localtime

    return data_dict

def insert_data(list):
    conn = sqlite3.connect('test.db')
    c = conn.cursor()
    try:
        id = max(c.execute("select max(id) from monthly_card").fetchall())
        max_id = int(id[0])
        for data in list:
            card_number = data['card_number']
            db_car_number = c.execute("select card_number from monthly_card").fetchall()
            if card_number in db_car_number:
                break
            else:
                car_type = data['car_type']
                localtime = data['localtime']
                max_id += 1
                c.execute("insert into monthly_card values (?,?,?,?)", (max_id, card_number, car_type, localtime))

    except sqlite3.OperationalError:
        sql = '''create table if not exists monthly_card
                (id int primary key not null,
                card_number text not null,
                car_type text not null,
                valid text not null);'''
        c.execute(sql)
        id = 0
        for data in list:
            try:
                card_number = data['card_number']
                db_car_number = c.execute("select card_number from monthly_card").fetchall()
                if card_number in db_car_number:
                    break
                else:
                    car_type = data['car_type']
                    localtime = data['localtime']
                    id += 1
                    c.execute("insert into monthly_card values (?,?,?,?)", (id, card_number, car_type, localtime))

            except sqlite3.OperationalError:
                card_number = data['car_number']
                car_type = data['car_type']
                localtime = data['localtime']
                id += 1
                c.execute("insert into monthly_card values (?,?,?,?)", (id, card_number, car_type, localtime))
    # print(type(id_1))
    # id = id_1.fetchall()
    conn.commit()
    conn.close()


# def select_data():
#     conn = sqlite3.connect('test.db')
#     c = conn.cursor()
#     db_car_number = c.execute("select card_number")

# test1 = make_date()
# my_list = []
# my_list.append(test1)
# insert_data(my_list)
# print('OK')

n = 500
my_list = []
while n:
    my_list.append(make_date())
    n-=1
insert_data(my_list)
print('OK')


相关内容

热门资讯

20余所985高校进场,新增1... 2026年高考前夕,教育部教育涉外监管信息网公布了新一轮中外合作办学审批名单:新批准设立86个合作办...
洪秀柱前助理:赖清德否定农产品... 针对赖清德宣称台湾农产品销往中国大陆已无竞争力,将市场重心转移至美国与日本才是正确方向,选区位于南投...
原创 小... 前言 大家好,我是听澜。 小行星当年被集体踢出行星圈,真的是因为数量太多、科学家懒得起名吗? 从18...
2026 6月拍照推荐,荣耀6... 在2026年618时期CCD风格拍照手机排行榜中,荣耀600 系列凭借2亿AI超清主摄与5000万像...
口碑好的苹果谷歌通用防丢器现货... 随着苹果“Find My”网络与谷歌“Find My Device”生态的成熟,通用型蓝牙防丢器已成...
外媒:苹果寻求获准从长鑫存储购... 据英国《金融时报》27日报道,六位知情人士透露,为缓解内存芯片涨价带来的成本压力,苹果公司正向美国政...
美国查封近400个盗播世界杯赛... 美国司法部官员26日说,美国查封了近400个非法直播世界杯赛事的互联网域名。 美国司法部说,被查封的...
原创 欧... 文/王新喜 在这个被热浪炙烤的夏天,中国空调在欧洲被抢疯,欧洲人的夏天被拯救了。 以法国为例,如今法...
市场监管总局给AI立规矩 智能... 央广网北京6月26日消息(记者胡波 陈爱海)据中央广播电视总台经济之声报道,随着大模型技术迭代升级,...
原创 美... 看起来您提供的内容主要是一些乱码、符号和零散的年份数字,没有完整的语义或连续的句子可供改写。我可以帮...