Python常用方法

时间转换

python 复制代码
from datetime import datetime, timedelta, timezone

# 原始日期字符串
date_str = '20250217'
datetime_str = '20250217000000'

# 解析为 UTC 时间
date_obj = datetime.strptime(date_str, '%Y%m%d')
# 会增加8个小时
#date_obj = datetime.strptime(date_str, '%Y%m%d').replace(tzinfo=timezone.utc)
# 同样会增加8个小时
#date_obj = datetime.strptime(datetime_str, '%Y%m%d%H%M%S').replace(tzinfo=timezone.utc)

#date_obj = date_obj - timedelta(hours=8)

# 获取 UTC 时间戳
timestamp = int(date_obj.timestamp())
print(f"UTC 时间 {date_str} 的时间戳为: {timestamp}")

# 计算7天后的 UTC 时间
seven_days_later = date_obj + timedelta(days=7)
seven_days_timestamp = int(seven_days_later.timestamp())
print(f"UTC 时间 {date_str} 7天后的时间戳为: {seven_days_timestamp}")

传递参数

test.py

python 复制代码
from datetime import datetime
import os

# 原始日期字符串
date_str = '20250217'
# 解析为 UTC 时间
date_obj = datetime.strptime(date_str, '%Y%m%d')
# 获取 UTC 时间戳
timestamp = int(date_obj.timestamp())
print(f"UTC 时间 {date_str} 的时间戳为: {timestamp}")

os.system('python test1.py ' + date_str)

test1.py

python 复制代码
import sys

print('test1 ' + sys.argv[1])

执行结果

python 复制代码
C:\Users\admin\Desktop>python test.py
UTC 时间 20250217 的时间戳为: 1739721600
test1 20250217

操作数据库

python 复制代码
# python.exe -m pip install --upgrade pip
# python -m pip install pymysql
import pymysql

class MySQLTester:
    def __init__(self):
        # 数据库连接配置
        self.db_config = {
            'host': '192.168.1.100',       # 数据库地址 (如果是远程请填IP)
            'port': 3306,                  # 端口
            'user': 'root',                # 用户名 (建议使用之前配置好的支持远程的用户)
            'password': '*********',       # 密码
            'database': 'test',            # 数据库名 (请确保该数据库已存在)
            'charset': 'utf8mb4',          # 字符集,防止中文乱码
            'cursorclass': pymysql.cursors.DictCursor # 使用字典游标,查询结果以字典形式返回
        }
        self.conn = None
        self.cursor = None

    def connect(self):
        """建立数据库连接"""
        try:
            self.conn = pymysql.connect(**self.db_config)
            self.cursor = self.conn.cursor()
            print("✅ 数据库连接成功!")
            return True
        except pymysql.Error as e:
            print(f"❌ 连接失败: {e}")
            return False

    def query(self, sql, params=None):
        """执行查询操作 (SELECT)"""
        try:
            self.cursor.execute(sql, params)
            results = self.cursor.fetchall()
            return results
        except pymysql.Error as e:
            print(f"❌ 查询出错: {e}")
            return None

    def execute(self, sql, params=None):
        """执行增删改操作 (INSERT, UPDATE, DELETE)"""
        try:
            self.cursor.execute(sql, params)
            self.conn.commit() # 提交事务
            print(f"✅ 操作成功,影响行数: {self.cursor.rowcount}")
            return True
        except pymysql.Error as e:
            self.conn.rollback() # 出错回滚
            print(f"❌ 操作失败: {e}")
            return False

    def close(self):
        """关闭连接"""
        if self.cursor:
            self.cursor.close()
        if self.conn:
            self.conn.close()
        print("🔌 连接已关闭")

# --- 主程序入口 ---
if __name__ == "__main__":
    db = MySQLTester()
    
    # 1. 连接数据库
    if db.connect():
        
        # --- 准备工作:创建一个测试表 (如果不存在) ---
        # 注意:请确保你的数据库 'test_db' 已经存在
        create_table_sql = """
        CREATE TABLE IF NOT EXISTS users (
            id INT AUTO_INCREMENT PRIMARY KEY,
            name VARCHAR(50) NOT NULL,
            age INT,
            email VARCHAR(50)
        ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
        """
        db.execute(create_table_sql)

        # --- 测试 1: 插入数据 (防止 SQL 注入) ---
        print("\n--- 测试插入数据 ---")
        insert_sql = "INSERT INTO users (name, age, email) VALUES (%s, %s, %s)"
        db.execute(insert_sql, ('张三', 25, 'zhangsan@example.com'))
        db.execute(insert_sql, ('李四', 30, 'lisi@example.com'))

        # --- 测试 2: 查询数据 ---
        print("\n--- 测试查询数据 ---")
        select_sql = "SELECT * FROM users"
        results = db.query(select_sql)
        
        if results:
            print(f"共查询到 {len(results)} 条数据:")
            for row in results:
                # 因为使用了 DictCursor,这里 row 是字典格式
                print(f"ID: {row['id']}, 姓名: {row['name']}, 年龄: {row['age']}")

        # --- 测试 3: 更新数据 ---
        print("\n--- 测试更新数据 ---")
        update_sql = "UPDATE users SET age = %s WHERE name = %s"
        db.execute(update_sql, (28, '张三'))

        # --- 测试 4: 再次查询验证更新 ---
        verify_sql = "SELECT * FROM users WHERE name = %s"
        verify_res = db.query(verify_sql, ('张三',))
        if verify_res:
            print(f"更新后张三的年龄: {verify_res[0]['age']}")

        # --- 测试 5: 删除数据 ---
        print("\n--- 测试删除数据 ---")
        delete_sql = "DELETE FROM users WHERE name = %s"
        db.execute(delete_sql, ('李四',))

        # 关闭连接
        db.close()
相关推荐
玉宇夕落1 分钟前
Props的传递学习
前端
加号32 分钟前
【C#】 Web API 自定义配置函数请求路径:从路由本质到灵活架构设计
开发语言·c#
月光刺眼2 分钟前
JS 底层执行机制探讨:执行上下文、变量提升与调用栈
前端·javascript
KANGBboy8 分钟前
java知识四(面向对象编程)
android·java·开发语言
雪的季节13 分钟前
矢量数据提取分析(甲方平台)
开发语言
|_⊙18 分钟前
Linux 信号
运维·服务器·前端
ZC跨境爬虫30 分钟前
跟着 MDN 学 JavaScript day_1:什么是 JavaScript?
开发语言·前端·javascript·ecmascript
广州华水科技31 分钟前
单北斗GNSS水库变形监测系统的应用与发展分析
前端
吠品40 分钟前
PyTorch 踩坑:libtorch_cpu.so 找不到 iJIT_NotifyEvent 符号
前端·vue.js·elementui
qq_25183645743 分钟前
基于java Web 日化商超库存管理系统设计与实现
java·开发语言·前端