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()
相关推荐
爱勇宝3 小时前
大多数人不是在使用 AI 赚钱,而是在帮 AI 公司赚钱
前端·后端·程序员
冬奇Lab4 小时前
每日一个开源项目(第143篇):page-agent - 纯 JS 的网页 GUI Agent,无需截图、无需插件、无需后端
前端·人工智能·agent
IT_陈寒8 小时前
React的这个渲染问题连官方文档都没说清楚
前端·人工智能·后端
金銀銅鐵9 小时前
[Python] 扩展欧几里得算法
python·数学·算法
Duckdblab9 小时前
DuckDB 性能调优终极指南:打造闪电般的分析体验
python
追逐时光者9 小时前
别再满网找零散工具了,腾讯 QQ 浏览器这个“帮小忙”工具箱真能省时间
前端·后端
带派擂总9 小时前
Python全栈开发精华版最全合集(包含各种面试题) Day24_异常和错误
python
Asmewill11 小时前
grep&curl命令学习笔记
前端
stringwu11 小时前
Flutter 开发必备:MVI 架构的高效实现指南
前端·flutter
用户21366100357212 小时前
Vue2组件化开发与父子通信
前端·vue.js