如何使用Python操作数据库(SQLite/MySQL/PostgreSQL)?

Python操作数据库的核心思路是建立连接、获取游标、执行SQL、处理结果、提交事务和关闭连接。该流程适用于SQLite、MySQL和PostgreSQL,遵循DB-API 2.0规范,接口一致,仅连接参数和库不同。SQLite轻量,适合本地开发;MySQL广泛用于Web应用;PostgreSQL功能强大,适合复杂业务。安全性方面需使用参数化查询防SQL注入,验证输入,遵循最小权限原则,并妥善处理错误。连接池可提升高并发下的性能。

如何使用python操作数据库(sqlite/mysql/postgresql)?

Python操作数据库的核心思路其实很简单:建立连接、获取游标、执行SQL语句、处理结果、提交或回滚事务,最后关闭连接。无论你是用SQLite、MySQL还是PostgreSQL,这一套流程都大同小异,主要区别在于使用的Python库和连接参数。掌握了这套范式,就能灵活地与各种关系型数据库打交道。

在Python中,与关系型数据库交互通常遵循DB-API 2.0规范,这使得不同数据库的客户端库(如

sqlite3

PyMySQL

psycopg2

)在接口上保持高度一致。这意味着你学会了一种,其他也就触类旁通了。

解决方案

让我们一步步看看如何具体操作。

1. SQLite:轻量级本地数据库

立即学习“Python免费学习笔记(深入)”;

SQLite是Python标准库的一部分,无需额外安装。它以文件形式存储数据,非常适合本地开发、小型应用或作为配置存储。

import sqlite3def operate_sqlite():    conn = None # 初始化连接对象    try:        # 连接到数据库文件,如果文件不存在则创建        conn = sqlite3.connect('my_database.db')        cursor = conn.cursor()        # 创建表        cursor.execute('''            CREATE TABLE IF NOT EXISTS users (                id INTEGER PRIMARY KEY AUTOINCREMENT,                name TEXT NOT NULL,                age INTEGER            )        ''')        print("表 'users' 创建或已存在。")        # 插入数据        # 注意使用参数化查询,防止SQL注入        cursor.execute("INSERT INTO users (name, age) VALUES (?, ?)", ('Alice', 30))        cursor.execute("INSERT INTO users (name, age) VALUES (?, ?)", ('Bob', 24))        print("数据插入成功。")        # 查询数据        cursor.execute("SELECT * FROM users WHERE age > ?", (25,))        print("n查询结果 (年龄 > 25):")        for row in cursor.fetchall():            print(row)        # 更新数据        cursor.execute("UPDATE users SET age = ? WHERE name = ?", (31, 'Alice'))        print("数据更新成功。")        # 删除数据        cursor.execute("DELETE FROM users WHERE name = ?", ('Bob',))        print("数据删除成功。")        # 再次查询,确认更新和删除        cursor.execute("SELECT * FROM users")        print("n当前所有用户:")        for row in cursor.fetchall():            print(row)        # 提交事务        conn.commit()        print("事务已提交。")    except sqlite3.Error as e:        print(f"数据库操作错误: {e}")        if conn:            conn.rollback() # 发生错误时回滚            print("事务已回滚。")    finally:        if conn:            conn.close() # 确保关闭连接            print("数据库连接已关闭。")# operate_sqlite()

2. MySQL:广泛使用的关系型数据库

操作MySQL需要安装第三方库,比如

PyMySQL

import pymysqldef operate_mysql():    conn = None    try:        # 连接到MySQL服务器        # 请替换为你的数据库信息        conn = pymysql.connect(            host='localhost',            user='your_mysql_user',            password='your_mysql_password',            database='your_database_name',            charset='utf8mb4',            cursorclass=pymysql.cursors.DictCursor # 返回字典形式的行        )        cursor = conn.cursor()        # 创建表        cursor.execute('''            CREATE TABLE IF NOT EXISTS products (                id INT AUTO_INCREMENT PRIMARY KEY,                name VARCHAR(255) NOT NULL,                price DECIMAL(10, 2)            )        ''')        print("表 'products' 创建或已存在。")        # 插入数据        cursor.execute("INSERT INTO products (name, price) VALUES (%s, %s)", ('Laptop', 1200.50))        cursor.execute("INSERT INTO products (name, price) VALUES (%s, %s)", ('Mouse', 25.99))        print("数据插入成功。")        # 查询数据        cursor.execute("SELECT * FROM products WHERE price > %s", (100.00,))        print("n查询结果 (价格 > 100):")        for row in cursor.fetchall():            print(row)        # 更新数据        cursor.execute("UPDATE products SET price = %s WHERE name = %s", (1250.00, 'Laptop'))        print("数据更新成功。")        # 删除数据        cursor.execute("DELETE FROM products WHERE name = %s", ('Mouse',))        print("数据删除成功。")        conn.commit()        print("事务已提交。")    except pymysql.Error as e:        print(f"数据库操作错误: {e}")        if conn:            conn.rollback()            print("事务已回滚。")    finally:        if conn:            conn.close()            print("数据库连接已关闭。")# operate_mysql()

3. PostgreSQL:功能强大的企业级数据库

操作PostgreSQL需要安装

psycopg2

库。

import psycopg2def operate_postgresql():    conn = None    try:        # 连接到PostgreSQL服务器        # 请替换为你的数据库信息        conn = psycopg2.connect(            host='localhost',            database='your_pg_database_name',            user='your_pg_user',            password='your_pg_password'        )        cursor = conn.cursor()        # 创建表        cursor.execute('''            CREATE TABLE IF NOT EXISTS orders (                id SERIAL PRIMARY KEY,                item_name VARCHAR(255) NOT NULL,                quantity INTEGER            )        ''')        print("表 'orders' 创建或已存在。")        # 插入数据        cursor.execute("INSERT INTO orders (item_name, quantity) VALUES (%s, %s)", ('Keyboard', 5))        cursor.execute("INSERT INTO orders (item_name, quantity) VALUES (%s, %s)", ('Monitor', 2))        print("数据插入成功。")        # 查询数据        cursor.execute("SELECT * FROM orders WHERE quantity > %s", (3,))        print("n查询结果 (数量 > 3):")        for row in cursor.fetchall():            print(row)        # 更新数据        cursor.execute("UPDATE orders SET quantity = %s WHERE item_name = %s", (6, 'Keyboard'))        print("数据更新成功。")        # 删除数据        cursor.execute("DELETE FROM orders WHERE item_name = %s", ('Monitor',))        print("数据删除成功。")        conn.commit()        print("事务已提交。")    except psycopg2.Error as e:        print(f"数据库操作错误: {e}")        if conn:            conn.rollback()            print("事务已回滚。")    finally:        if conn:            cursor.close()            conn.close()            print("数据库连接已关闭。")# operate_postgresql()

Python数据库连接选择:SQLite、MySQL与PostgreSQL适用场景解析

选择哪种数据库,这其实是个很经典的“看菜吃饭”问题,没有绝对的优劣,只有适不适合你的项目。我个人觉得,很多人在项目初期可能并不会深究,但随着项目发展,数据库的选择会越来越凸显其重要性。

SQLite:嵌入式与轻量级之选

适用场景: 我通常在以下几种情况首选SQLite:桌面应用或移动应用: 作为本地数据存储,无需独立服务器进程,直接嵌入应用内部,比如一个简单的个人笔记应用。开发与测试: 项目初期快速原型开发,或者单元测试时,SQLite非常方便,因为它不需要复杂的配置,一个文件就是数据库。小型网站或个人博客: 如果访问量不大,数据量也不大,SQLite完全可以胜任,省去了维护数据库服务器的麻烦。配置管理或缓存: 存储一些不经常变动但需要持久化的配置信息,或者作为简单的本地缓存。特点:零配置: 不需要安装和管理数据库服务器,数据存储在一个文件中。高可移植性: 数据库文件可以直接复制到任何地方使用。性能: 对于单用户或并发量不高的场景,性能表现优秀。限制:并发写入: 对高并发写入支持不佳,因为锁是文件级别的。复杂权限管理: 缺乏细粒度的用户权限控制。

MySQL:Web应用与通用业务的主力军

适用场景: MySQL是我接触最多的数据库,尤其在Web开发领域。中小型到大型Web应用: 无论是博客、电商、社交平台,MySQL都是一个非常成熟且广泛的选择。通用业务系统: 大多数企业级应用,如果对事务一致性要求不是极致严格,MySQL都能很好地支撑。LAMP/LEMP栈: 作为经典技术栈的一部分,拥有庞大的社区支持和丰富的工具链。特点:成熟稳定: 经过长时间考验,非常稳定可靠。性能优异: 在读操作上表现出色,通过各种优化手段也能很好地处理写入。社区庞大: 遇到问题很容易找到解决方案,资源丰富。可扩展性: 支持主从复制、分库分表等多种扩展方案。限制:事务处理: 相比PostgreSQL,在某些高级事务特性和严格的ACID合规性上略逊一筹。SQL标准支持: 对SQL标准的某些高级特性支持不如PostgreSQL全面。

PostgreSQL:数据完整性与高级功能的王者

适用场景: 当我需要更强的数据完整性、更复杂的查询或者处理地理空间数据时,PostgreSQL是我的首选。金融、GIS(地理信息系统)等对数据一致性、完整性要求极高的领域: PostgreSQL的ACID特性非常强大。大数据分析与数据仓库: 支持更复杂的SQL查询,如窗口函数、CTE(Common Table Expressions),以及丰富的扩展(如PostGIS用于地理空间数据)。需要JSONB等高级数据类型: 对非结构化数据的支持也很好,可以更好地融合关系型和NoSQL的优点。企业级应用: 许多大型企业倾向于PostgreSQL,因为它提供了更强大的功能和更好的可扩展性。特点:ACID合规性: 严格遵循事务的原子性、一致性、隔离性、持久性。功能丰富: 支持更多高级SQL特性、自定义函数、存储过程、多种索引类型、丰富的数据类型(数组、JSONB等)。扩展性强: 拥有强大的扩展生态系统,可以轻松添加新功能。开源免费: 拥有BSD许可证,可以自由使用和修改。限制:学习曲线: 功能强大也意味着学习成本相对较高。资源消耗: 在某些情况下,可能比MySQL占用更多资源。

总结一下,如果只是快速启动一个小项目或做本地数据存储,SQLite轻巧方便;如果构建常见的Web应用,MySQL是久经考验的可靠选择;而如果你的项目对数据完整性、复杂查询有高要求,或者需要处理特殊数据类型,PostgreSQL则提供了更强大的功能集。

提升Python数据库操作安全性:避免SQL注入与常见漏洞

在数据库操作中,安全性永远是绕不过去的话题,尤其是SQL注入,那简直是悬在程序员头上的达摩克利斯之剑。我见过太多因为忽视安全导致数据泄露的案例,所以这块内容我认为是重中之重。

1. 坚决使用参数化查询(Prepared Statements)

这是防御SQL注入最核心、最有效的手段,没有之一。它的原理很简单:将SQL语句和参数分开传递给数据库,数据库会先编译SQL模板,再将参数安全地绑定进去,确保参数不会被当作SQL代码的一部分执行。

错误示例(易受SQL注入):

# 假设 username 和 password 来自用户输入username = "admin"password = "' OR '1'='1" # 恶意输入sql = f"SELECT * FROM users WHERE username = '{username}' AND password = '{password}'"# 最终SQL可能变成:SELECT * FROM users WHERE username = 'admin' AND password = '' OR '1'='1'# 导致无需密码即可登录cursor.execute(sql)

正确示例(参数化查询):

# SQLitecursor.execute("SELECT * FROM users WHERE username = ? AND password = ?", (username, password))# MySQL (PyMySQL)cursor.execute("SELECT * FROM users WHERE username = %s AND password = %s", (username, password))# PostgreSQL (psycopg2)cursor.execute("SELECT * FROM users WHERE username = %s AND password = %s", (username, password))

你会发现,不同数据库驱动的占位符可能不同(

?

%s

),但核心思想一致:不要直接拼接用户输入到SQL字符串中。Python DB-API规范强制要求所有数据库驱动都支持参数化查询,所以这是我们最可靠的武器。

2. 严格的输入验证与数据清洗

虽然参数化查询能防SQL注入,但这并不意味着你可以放松对用户输入的警惕。在数据进入数据库之前,对所有用户输入进行验证和清洗是另一个重要的安全层。

数据类型验证: 确保用户输入的年龄是整数,邮箱是有效的格式,电话号码是数字等。

长度限制: 防止过长的输入导致数据库字段溢出或DoS攻击。

字符过滤: 移除或转义不必要的特殊字符,例如HTML标签(防止XSS攻击)。

业务逻辑验证: 确保输入符合你的业务规则,例如,一个商品的库存不能是负数。

def validate_age(age_str):    try:        age = int(age_str)        if 0 < age < 150: # 合理的年龄范围            return age        else:            raise ValueError("年龄不在合理范围。")    except ValueError:        raise ValueError("年龄必须是有效的数字。")# 使用前先验证try:    user_age = validate_age(request_data.get('age'))    # 之后再将 user_age 传给参数化查询except ValueError as e:    print(f"输入验证失败: {e}")    # 返回错误给用户

3. 最小权限原则(Principle of Least Privilege)

为不同的应用程序或服务创建专门的数据库用户,并只授予它们完成其任务所需的最小权限。

避免使用

root

用户连接应用: 这是一个非常常见的错误,一旦应用被攻破,攻击者就能获得数据库的完全控制权。

按需授权: 如果一个应用只需要读取数据,就只给它

SELECT

权限;如果需要写入,就给

INSERT

UPDATE

DELETE

-- 创建一个只读用户CREATE USER 'readonly_app'@'localhost' IDENTIFIED BY 'secure_password';GRANT SELECT ON your_database.* TO 'readonly_app'@'localhost';-- 创建一个读写用户CREATE USER 'webapp_user'@'localhost' IDENTIFIED BY 'another_secure_password';GRANT SELECT, INSERT, UPDATE, DELETE ON your_database.* TO 'webapp_user'@'localhost';FLUSH PRIVILEGES;

4. 错误处理与日志记录

不要在生产环境中向用户暴露详细的数据库错误信息,这可能会泄露数据库结构、表名、字段名等敏感信息。

捕获异常: 使用

try...except

块捕获数据库操作可能抛出的异常。

通用错误信息: 向用户显示友好的、通用的错误消息(例如:“操作失败,请稍后再试。”)。

详细日志: 将详细的错误信息记录到日志文件中,供开发人员和运维人员排查问题。

import logginglogging.basicConfig(level=logging.ERROR, filename='app_errors.log')try:    # 数据库操作    passexcept SomeDatabaseError as e:    logging.error(f"数据库操作失败: {e}")    # 向用户返回一个通用错误消息    return {"error": "Internal server error, please try again later."}

安全性是一个持续的过程,没有一劳永逸的解决方案。将这些实践融入你的开发流程,才能构建出更健壮、更值得信赖的应用程序。

数据库连接与事务管理:提升性能与数据一致性的关键实践

在实际项目中,尤其是在处理高并发或复杂业务逻辑时,仅仅知道如何执行SQL语句是远远不够的。如何高效地管理数据库连接,以及确保数据操作的原子性和一致性,才是真正考验开发者功力的地方。这就像是开车,你知道怎么踩油门刹车,但要开得又快又稳,还得懂交通规则和车辆维护。

1. 高效管理数据库连接:连接池(Connection Pooling)

每次与数据库建立连接都需要消耗时间和系统资源,包括TCP握手、认证等。如果每次请求都建立新连接,然后关闭,在高并发场景下会造成巨大的性能开销。连接池就是解决这个问题的利器。

工作原理: 连接池预先创建一定数量的数据库连接,并将它们保存在一个池子里。当应用程序需要连接时,它从池中“借用”一个已存在的连接;当操作完成后,连接不会被关闭,而是“归还”到池中,供其他请求复用。为什么需要:性能提升: 显著减少连接建立和关闭的开销。资源控制: 限制并发连接数,防止数据库过载。连接复用: 提高数据库服务器的效率。如何在Python中使用:Web框架集成: 许多Web框架(如Django

以上就是如何使用Python操作数据库(SQLite/MySQL/PostgreSQL)?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1369920.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
如何用Python发送邮件?
上一篇 2025年12月14日 10:05:01
Python中的垃圾回收机制是如何工作的?
下一篇 2025年12月14日 10:05:11

相关推荐

  • composer require-dev和require有什么不同_Composer Require与Require-Dev区别解析

    require用于声明项目运行必需的依赖,如框架、数据库组件和第三方SDK,这些包会随项目部署到生产环境;2. require-dev用于声明仅在开发和测试阶段需要的工具,如PHPUnit、PHPStan、Faker等,不会默认部署到生产环境;3. 安装时composer install根据环境决定…

    2026年5月10日
    1000
  • 修复Django电商项目中AJAX过滤产品列表图片不显示问题

    在Django电商项目中,当使用AJAX动态加载过滤后的产品列表时,常遇到图片无法正常显示的问题。这通常是由于前端模板中图片加载方式(如data-setbg属性结合JavaScript库)与AJAX动态内容更新机制不兼容所致。解决方案是直接在AJAX返回的HTML中使用标准的标签来渲染图片,确保浏览…

    2026年5月10日
    000
  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • Matplotlib 地图中多类型图例的创建与优化

    Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化

    本教程旨在解决matplotlib地图可视化中,如何在一个图例中同时展示颜色块(如区域分类)和自定义标记(如特定兴趣点)的问题。文章详细介绍了当传统`patch`对象无法正确显示标记时,如何利用`matplotlib.lines.line2d`创建标记图例句柄,并将其与颜色块图例句柄合并,从而生成一…

    2026年5月10日 用户投稿
    300
  • Golang JSON序列化:控制敏感字段暴露的最佳实践

    本教程探讨golang中如何高效控制结构体字段在json序列化时的可见性。当需要将包含敏感信息的结构体数组转换为json响应时,通过利用`encoding/json`包提供的结构体标签,特别是`json:”-“`,可以轻松实现对特定字段的忽略,从而避免敏感数据泄露,确保api…

    2026年5月10日
    000
  • 利用海象运算符简化条件赋值:Python教程与最佳实践

    本文旨在探讨Python中海象运算符(:=)在条件赋值场景下的应用。通过对比传统if/else语句与海象运算符,以及条件表达式,分析海象运算符在简化代码、提高可读性方面的优势与局限性。并通过具体示例,展示如何在列表推导式等场景下合理使用海象运算符,同时强调其潜在的复杂性及替代方案,帮助开发者更好地掌…

    2026年5月10日
    100
  • Debian syslog性能优化技巧有哪些

    提升Debian系统syslog (通常基于rsyslog)性能,关键在于精简配置和高效处理日志。以下策略能有效优化日志管理,提升系统整体性能: 精简配置,高效加载: 在rsyslog配置文件中,仅加载必要的输入、输出和解析模块。 使用全局指令设置日志级别和格式,避免不必要的处理。 自定义模板: 创…

    2026年5月10日
    000
  • 怎么在PHP代码中实现图片上传功能_PHP图片上传功能实现与安全处理教程

    首先创建含enctype的HTML表单,再用PHP接收文件,检查目录、移动临时文件,验证类型与大小,生成唯一文件名,并调整php.ini限制以确保上传成功。 如果您尝试在PHP项目中添加图片上传功能,但服务器无法正确接收或保存文件,则可能是由于表单配置、文件处理逻辑或安全限制的问题。以下是实现该功能…

    2026年5月10日
    100
  • 比特币新手教程 比特币交易平台有哪些

    比特币是一种去中心化的数字货币,基于区块链技术实现点对点交易,具有匿名性、有限发行和不可篡改等特点;新手可通过交易所购买,P2P交易获得比特币,常用平台包括Binance、OKX和Huobi;交易流程包括注册账户、实名认证、绑定支付方式、充值法币并下单购买,可选择市价单或限价单;比特币存储方式有交易…

    2026年5月10日
    000
  • c++中的SFINAE技术是什么_c++模板编程中的SFINAE原理与应用

    SFINAE 是“替换失败不是错误”的原则,指模板实例化时若参数替换导致错误,只要存在其他合法候选,编译器不报错而是继续重载决议。它用于条件启用模板、类型检测等场景,如通过 decltype 或 enable_if 控制函数重载,实现类型特征判断。尽管 C++20 引入 Concepts 简化了部分…

    2026年5月10日
    000
  • HTML如何隐藏滚动条或去除滚动条

    滚动条可以存在也可以不存在,本文主要介绍了html 隐藏滚动条和去除滚动条的方法的相关资料,大家一起来学习一下html隐藏滚动条或去除滚动条的方法吧。 1. html 标签加属性 XML/HTML Code复制内容到剪贴板 2.body中加入以下代码 立即学习“前端免费学习笔记(深入)”; html…

    用户投稿 2026年5月10日
    100
  • Golang gRPC流式请求异常处理

    在Golang的gRPC流式通信中,必须通过context.Context处理异常。应监听上下文取消或超时,及时释放资源,设置合理超时,避免连接长时间挂起,并在goroutine中通过context控制生命周期。 在使用 Golang 和 gRPC 实现流式通信时,异常处理是确保服务健壮性的关键部分…

    2026年5月10日
    000
  • Go语言mgo查询构建:深入理解bson.M与日期范围查询的正确实践

    本文旨在解决go语言mgo库中构建复杂查询时,特别是涉及嵌套`bson.m`和日期范围筛选的常见错误。我们将深入剖析`bson.m`的类型特性,解释为何直接索引`interface{}`会导致“invalid operation”错误,并提供一种推荐的、结构清晰的代码重构方案,以确保查询条件能够正确…

    2026年5月10日
    100
  • vscode上怎么运行html_vscode上运行html步骤【指南】

    首先保存文件为.html格式,再通过浏览器或Live Server插件打开预览;推荐安装Live Server实现本地服务器运行与实时刷新,提升开发体验。 在 VS Code 上运行 HTML 文件并不需要复杂的配置,只需几个简单步骤即可预览页面效果。VS Code 本身是一个代码编辑器,不直接运行…

    2026年5月10日
    100
  • RichHandler与Rich Progress集成:解决显示冲突的教程

    在使用rich库的`richhandler`进行日志输出并同时使用`progress`组件时,可能会遇到显示错乱或溢出问题。这通常是由于为`richhandler`和`progress`分别创建了独立的`console`实例导致的。解决方案是确保日志处理器和进度条组件共享同一个`console`实例…

    2026年5月10日
    000
  • 修复点击时按钮抖动:CSS垂直对齐实践

    本文探讨了在Web开发中,交互式按钮(如播放/暂停按钮)在点击时发生意外垂直位移的问题。通过分析CSS样式变化对元素布局的影响,我们发现这是由于按钮不同状态下的边框样式和内边距改变,以及默认的垂直对齐行为共同作用所致。核心解决方案是利用CSS的vertical-align属性,将其设置为middle…

    2026年5月10日
    100
  • Golang goroutine与channel调试技巧

    使用go run -race检测数据竞争,结合runtime.NumGoroutine监控协程数量,通过pprof分析阻塞调用栈,利用select超时避免永久阻塞,有效排查goroutine泄漏、死锁和数据竞争问题。 Go语言的goroutine和channel是并发编程的核心,但它们也带来了调试上…

    2026年5月10日
    000
  • 页面中文本域的值怎么设置

    标签定义多行的文本输入控件。 文本区中可容纳无限数量的文本,其中的文本的默认字体是等宽字体(通常是 Courier)。 可以通过 cols 和 rows 属性来规定 textarea 的尺寸,不过更好的办法是使用 CSS 的 height 和 width 属性。 注释:在文本输入区内的文本行间,用 …

    2026年5月10日
    000
  • 《魔兽世界》将于6月11日开启国服回归技术测试

    《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试《魔兽世界》将于6月11日开启国服回归技术测试

    《%ign%ignore_a_1%re_a_1%》官方宣布,将于6月11日开启国服回归技术测试,时间为7天,并称可以在6月内正式开服,玩家们可以访问官网下载战网客户端并预下载“巫妖王之怒”客户端,技术测试详情见下图。 WordAi WordAI是一个AI驱动的内容重写平台 53 查看详情 以上就是《…

    2026年5月10日 用户投稿
    200
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信