学python的第二十一天

生成激活码,连接数据库,并保存到数据库

1,生成激活码

python 复制代码
# 1 生成激活码
import random  # 导入随机数模块
import os  # 导入os模块
import string  # 导入字符串模块


def GenKey(length):  # 定义生成激活码函数
    chars = string.ascii_letters + string.digits  # 生成所有字母和数字
    return ''.join(random.choice(chars) for i in range(length))


def SaveKey(content):  # 定义保存激活码函数
    f = open("key.txt", 'a')  # 打开文件,以追加模式写入
    f.write(content + "\n")  # 写入激活码
    f.close()  # 关闭文件


if __name__ == '__main__':  # 判断是否是主程序
    for i in range(200):  # 循环200次
        value = GenKey(20)  # 生成20位的激活码
        print(value)  # 输出激活码
        SaveKey(value)  # 保存激活码
# **************************************************************************************

2,生成的激活码保存到sqlite3数据库

python 复制代码
# 2 生成的激活码保存到sqlite3数据库
import random  # 导入随机数模块
import sqlite3  # 导入sqlite3模块
import string  # 导入字符串模块

# 连接数据库
conn = sqlite3.connect('keys.db')
# 获取游标
c = conn.cursor()


def creat_table():
    # 调用execute方法创建表
    c.execute('CREATE TABLE IF NOT EXISTS keys (id INTEGER PRIMARY KEY AUTOINCREMENT, key TEXT NOT NULL)')
    # 提交事务
    conn.commit()


def GenKey(length):  # 定义生成激活码函数
    chars = string.ascii_letters + string.digits  # 生成所有字母和数字
    return ''.join(random.choice(chars) for i in range(length))


def SaveKey(content):  # 定义保存激活码函数
    # 使用占位符?来插入内容,这是防止SQL注入的推荐做法
    c.execute("INSERT INTO keys (key) VALUES (?)", (content,))
    # 提交事务
    conn.commit()


if __name__ == '__main__':  # 判断是否是主程序
    creat_table()  # 创建表

    for i in range(200):  # 循环200次
        value = GenKey(20)  # 生成20位的激活码
        print(value)  # 输出激活码
        SaveKey(value)  # 保存激活码

    conn.close()  # 关闭数据库连接
# **************************************************************************

3,生成激活码并保存到sqlite3数据库并生成一个激活码的二维码,生成的二维码保存到keys文件夹下

python 复制代码
# 3 生成激活码并保存到sqlite3数据库,并生成一个激活码的二维码,生成的二维码保存到keys文件夹下
import random
import sqlite3
import string
import qrcode
from qrcode.image.pil import PilImage

# 连接数据库
conn = sqlite3.connect('keys.db')
# 获取游标
c = conn.cursor()


def creat_table():
    c.execute('CREATE TABLE IF NOT EXISTS keys (id INTEGER PRIMARY KEY AUTOINCREMENT, key TEXT NOT NULL)')
    conn.commit()


def GenKey(length):
    chars = string.ascii_letters + string.digits
    return ''.join(random.choice(chars) for i in range(length))


def SaveKey(content, index):
    c.execute("INSERT INTO keys (key) VALUES (?)", (content,))
    conn.commit()
    # 生成二维码
    qr = qrcode.QRCode(
        version=1,
        error_correction=qrcode.constants.ERROR_CORRECT_L,
        box_size=10,
        border=5,
    )

    qr.add_data(content)
    qr.make(fit=True)
    # 保存二维码为图片
    img = qr.make_image(fill_color="black", back_color="white")
    img.save("keys/QR-{}.png".format(index))  # 保存到keys文件夹下,文件名包含激活码


if __name__ == '__main__':
    creat_table()

    # 确保keys文件夹存在
    import os

    if not os.path.exists('keys'):
        os.makedirs('keys')

    for i in range(1, 201):
        value = GenKey(20)
        print(value)
        SaveKey(value, i)

    conn.close()
# **************************************************************************************

4,生成激活码并保存到mysql数据库

python 复制代码
# 4 生成激活码并保存到mysql数据库
import random  # 导入随机数模块
import string  # 导入字符串模块
import mysql.connector  # 导入MySQL连接模块


# 定义生成激活码函数
def GenKey(length):
    chars = string.ascii_letters + string.digits
    return ''.join(random.choice(chars) for _ in range(length))


# 定义保存激活码函数
def SaveKey(content):
    # 创建数据库连接(可以考虑使用连接池)
    cnx = mysql.connector.connect(user='root', password='******',
                                  host='localhost',
                                  database='mysql')
    cursor = cnx.cursor()


    # 执行SQL语句,插入激活码
    add_key = ("INSERT INTO `keys` (`key_value`) "
               "VALUES (%s)")
    data = (content,)
    cursor.execute(add_key, data)
    cnx.commit()

    # 关闭数据库连接
    cursor.close()
    cnx.close()


if __name__ == '__main__':  # 判断是否是主程序
    # 考虑使用数据库连接池,或者在循环外部创建连接
    cnx = mysql.connector.connect(user='root', password='******',
                                  host='localhost',
                                  database='mysql')
    cursor = cnx.cursor()

    for i in range(200):  # 循环200次
        value = GenKey(20)  # 生成20位的激活码
        print(value)  # 输出激活码
        SaveKey(value)  # 保存激活码

    # 循环结束后关闭数据库连接
    cursor.close()
    cnx.close()
# ****************************************************************************************

5,生成激活码并保存到redis数据库

python 复制代码
# 5 生成激活码并保存到redis数据库
import redis
import random
import string


# 生成随机键的函数
def GenKey(length):
    letters = string.ascii_letters + string.digits
    return ''.join(random.choice(letters) for i in range(length))


# Redis管理类
class RedisManager:
    def __init__(self, host='localhost', port=6379, db=0, password=None):
        self.r = redis.Redis(host=host, port=port, db=db, password=password)

    def save_key(self, key, value):
        # 将布尔值转换为字符串
        if isinstance(value, bool):
            value = str(value).lower()
        try:
            self.r.set(key, value)
            print(f"Key {key} with value {value} saved to Redis successfully.")
        except redis.exceptions.RedisError as e:
            print(f"Error saving key to Redis: {e}")

    def close(self):
        self.r.close()

    # 主程序


if __name__ == '__main__':
    redis_manager = RedisManager(password='******')  # 创建RedisManager实例

    # 尝试保存一些键值对到Redis中
    for _ in range(200):  # 例如,保存10个键值对
        key = GenKey(20)  # 生成一个随机键
        value = bool(random.randint(0, 1))  # 生成一个随机布尔值作为值
        redis_manager.save_key(key, value)  # 调用save_key方法保存键值对

    redis_manager.close()  # 关闭Redis连接
#****************************************************************************************
相关推荐
数据智能老司机4 小时前
精通 Python 设计模式——分布式系统模式
python·设计模式·架构
数据智能老司机5 小时前
精通 Python 设计模式——并发与异步模式
python·设计模式·编程语言
数据智能老司机5 小时前
精通 Python 设计模式——测试模式
python·设计模式·架构
数据智能老司机5 小时前
精通 Python 设计模式——性能模式
python·设计模式·架构
c8i5 小时前
drf初步梳理
python·django
每日AI新事件5 小时前
python的异步函数
python
这里有鱼汤6 小时前
miniQMT下载历史行情数据太慢怎么办?一招提速10倍!
前端·python
databook16 小时前
Manim实现脉冲闪烁特效
后端·python·动效
程序设计实验室16 小时前
2025年了,在 Django 之外,Python Web 框架还能怎么选?
python
倔强青铜三18 小时前
苦练Python第46天:文件写入与上下文管理器
人工智能·python·面试