当前位置: 首页 > news >正文

利用python连接MySQL数据库并执行相关sql操作

一、新建MySQL数据库

1.启动MySQL服务

打开phpstudy,开启MySQL服务。如果开启失败的话,可以打开任务管理器,把正在运行的mysqld服务的进程进行关闭,再次打开MySQL服务即可启动。

2.新建MySQL数据库

选择数据库,点击创建数据库,在里面填写你准备创建数据库的名称、用户名和密码,填好后选择确定即可成功创建好一个新的MySQL数据库。

二、提升数据库用户的权限

1.复制root对应用户和密码

在刚才的数据库模块查看一个名为root的数据库,查看对应的用户和密码,如果是第一次使用的话,用户和密码应该也都是root,但密码可以点击右侧的操作进行修改。然后可以先复制粘贴到记事本内,后面的登入需要用到。

2.下载phpMyAdmin

选择软件管理,找到phpMyAdmin,如果没有下载的可以先进行下载。点击管理,打开phpMyAdmin

3.打开并登入phpMyAdmin

这里可以看到我们需要用户名和密码才能登入phpMyAdmin,用户和密码就是刚才查看并复制的,进行输入登入。

4.修改用户权限

选择账户,找到刚才你创建的数据库的用户名,然后点击右侧的修改权限。这里我就拿python用户举例,全局权限在新建数据库后对应的是USAGE,我这里是已经将权限提升过后的,所以才显示的ALL PRIVILEGES,这点不用担心。

全局权限这里的选择全部勾选,然后点击执行即可完成权限的提升。

三、连接MySQL数据库

1.建立MySQL连接

打开Navicat for MySQL,选择文件-->新建连接-->MySQL。

这里输入自己对应数据库的连接名、用户名和密码,输入完毕后可以先点击测试连接试试,没有问题最后点击确定。这样就建立起了和数据库的联系。

双击刚连接到的MySQL数据库,从原本的灰色变为绿色,说明数据库连接成功。找到我们的python库,点击新建表。

2.添加字段并新建表

点击添加字段,可以输入一些你想创建的名,比如说下面的id,name,count,添加完成后点击保存,并输入你想创建的表名。

3.添加数据

双击打开我们刚新建好的表,点击左下侧的小加号,进行数据创建,然后对应输入你自己想要输入的值即可,完成创建后点击小勾,进行保存。

四、执行python代码连接数据库

这里我会进行三套python代码连接MySQL数据库的演示。

1. 第一套python

其中user,password,database需要填写你自己新建数据库对应的数据库用户名,数据库密码,数据库名称。

import mysql.connector  # 导入MySQL连接器模块
from mysql.connector import Error  # 导入MySQL连接错误模块try:# 连接到MySQL数据库connection = mysql.connector.connect(host='localhost',  # 数据库主机地址user='xxx',  # 数据库用户名password='xxx',  # 数据库密码database='xxx'  # 数据库名称)if connection.is_connected():  # 如果连接成功db_Info = connection.get_server_info()  # 获取数据库服务器信息print("成功连接到 MySQL 数据库,服务器版本:", db_Info)  # 打印成功连接信息cursor = connection.cursor()  # 创建游标对象cursor.execute("select database();")  # 执行SQL查询以获取当前数据库record = cursor.fetchone()  # 获取查询结果print("你连接到的数据库是:", record[0])  # 打印连接的数据库名称except Error as e:  # 捕获可能的连接错误print("连接出错:", e)  # 打印连接错误信息finally:if connection.is_connected():  # 如果连接处于打开状态cursor.close()  # 关闭游标connection.close()  # 关闭连接print("MySQL连接已关闭")  # 打印连接已关闭的信息

执行python代码,运行结果如下:

可以很明显的看到输入的内容:

成功连接到 MySQL 数据库,服务器版本: 5.7.26

你连接到的数据库是: python

MySQL连接已关闭

2. 第二套python
import tkinter as tk  # 导入 tkinter 库
from tkinter import ttk, messagebox  # 导入 ttk 和 messagebox 模块
import mysql.connector  # 导入 MySQL 连接器模块
from mysql.connector import Error  # 导入错误处理模块# 连接到数据库的函数
def connect_to_database(host, user, password, database):try:# 尝试建立数据库连接connection = mysql.connector.connect(host=host, user=user, password=password, database=database)return connection  # 如果成功连接,返回连接对象except Error as e:# 如果连接失败,显示错误消息框messagebox.showerror("连接错误", str(e))return None  # 连接失败时返回 None# 执行 SQL 查询的函数
def run_query(connection, query):cursor = connection.cursor()try:cursor.execute(query)  # 执行 SQL 查询if "select" in query.lower():results = cursor.fetchall()  # 如果是 SELECT 查询,则获取所有结果return resultselse:connection.commit()  # 提交其他类型的查询(INSERT、UPDATE、DELETE)的更改return cursor.rowcount  # 返回受影响的行数except Error as e:messagebox.showerror("SQL错误", str(e))  # 显示 SQL 错误的消息框finally:cursor.close()  # 关闭游标# 当点击提交按钮时触发的函数
def on_submit():# 使用提供的凭据尝试连接到数据库connection = connect_to_database(host_var.get(), user_var.get(), pass_var.get(), db_var.get())if connection:messagebox.showinfo("连接成功", "成功连接到数据库")  # 如果连接成功,显示成功消息connection.close()  # 关闭连接root = tk.Tk()  # 创建主窗口
root.title("数据库连接")  # 设置窗口标题style = ttk.Style(root)  # 定义窗口样式
style.theme_use("clam")  # 使用主题样式# 设置窗口大小和位置
window_width = 400
window_height = 400
screen_width = root.winfo_screenwidth()
screen_height = root.winfo_screenheight()
x = (screen_width - window_width) // 2
y = (screen_height - window_height) // 2
root.geometry(f"{window_width}x{window_height}+{x}+{y}")center_frame = ttk.Frame(root)  # 创建一个居中的框架
center_frame.place(relx=0.5, rely=0.5, anchor=tk.CENTER)  # 放置在窗口中心# 创建输入字段和标签
host_var = tk.StringVar()
user_var = tk.StringVar()
pass_var = tk.StringVar()
db_var = tk.StringVar()ttk.Label(center_frame, text="主机地址").grid(row=0, column=0, padx=10, pady=10)
ttk.Entry(center_frame, textvariable=host_var).grid(row=0, column=1, padx=10, pady=10)ttk.Label(center_frame, text="用户名").grid(row=1, column=0, padx=10, pady=10)
ttk.Entry(center_frame, textvariable=user_var).grid(row=1, column=1, padx=10, pady=10)ttk.Label(center_frame, text="密码").grid(row=2, column=0, padx=10, pady=10)
ttk.Entry(center_frame, textvariable=pass_var, show="*").grid(row=2, column=1, padx=10, pady=10)ttk.Label(center_frame, text="数据库名称").grid(row=3, column=0, padx=10, pady=10)
ttk.Entry(center_frame, textvariable=db_var).grid(row=3, column=1, padx=10, pady=10)submit_btn = ttk.Button(center_frame, text="连接", command=on_submit)  # 创建连接按钮
submit_btn.grid(row=4, column=0, columnspan=2, pady=10)root.rowconfigure(0, weight=1)
root.columnconfigure(0, weight=1)root.mainloop()  # 运行主事件循环

执行python代码,运行结果如下:

在这个代码中,使用了messagebox.showerror和messagebox.showinfo这两个函数来创建弹框。

输入我们的数据库主机地址,数据库用户名,数据库密码,数据库名称。如果输入都是正确的,即弹出弹框,说明成功连接到数据库。

反之如果输入错误的话,即会返回连接错误。

3. 第三套python代码

最后一个才是所要讲解的python代码连接数据库后执行相关的sql操作,分别有静态和动态执行sql操作的python代码。代码需要注意的是xx部分是sql语句的执行内容,这个是要根据你自己数据库里的数据信息来填写再执行代码的。

a. 静态实现sql语句操作的python代码:
#静态执行sql语句操作import mysql.connector # 导入MySQL连接器模块
from mysql.connector import Error# 连接数据库
def connect_to_database(host, user, password, database):try:# 尝试建立数据库连接connection = mysql.connector.connect(host=host, user=user, password=password, database=database)print("数据库连接成功!")  # 连接成功提示return connection  # 返回连接对象except Error as e:print("数据库连接失败:", e)  # 连接失败提示return None# 执行 SQL 查询
def run_query(connection, query):cursor = connection.cursor()try:cursor.execute(query)  # 执行 SQL 查询if query.lower().startswith("select"):return cursor.fetchall()  # 如果是 SELECT 查询,返回所有结果else:connection.commit()  # 提交更改(INSERT、UPDATE、DELETE)return cursor.rowcount  # 返回受影响的行数except Error as e:print("SQL错误:", e)  # SQL 错误提示return Nonefinally:cursor.close()  # 关闭游标# 主函数
def main():host = input("请输入主机地址: ")  # 获取用户输入的主机地址user = input("请输入用户名: ")  # 获取用户输入的用户名password = input("请输入密码: ")  # 获取用户输入的密码database = input("请输入数据库名称: ")  # 获取用户输入的数据库名称connection = connect_to_database(host, user, password, database)  # 连接数据库if connection is None:returnwhile True:# 显示操作选项print("\n选择操作:")print("1. 查询")print("2. 插入")print("3. 更新")print("4. 删除")print("5. 退出")choice = input("请输入您的选择 (1-5): ")  # 获取用户选择if choice == "1":query = "SELECT * FROM view;"  # 查询语句elif choice == "2":query = "INSERT INTO view (id, name, count) VALUES (xx, 'xxx', xx);"  # 插入语句elif choice == "3":query = "UPDATE view SET name = 'xxx', count = xx WHERE id = xx;"  # 更新语句elif choice == "4":query = "DELETE FROM view WHERE id = xx;"  # 删除语句elif choice == "5":break  # 退出循环else:print("无效的选择!")  # 无效选择提示continueresult = run_query(connection, query)  # 执行用户选择的操作if isinstance(result, list):for row in result:print(row)  # 打印查询结果elif result is not None:print("操作成功,影响行数:", result)  # 打印受影响的行数if connection.is_connected():connection.close()  # 关闭数据库连接if __name__ == "__main__":main()  # 执行主函数

执行python代码,输入对应的数据库相关信息,输入正确即可显示以下内容:

数据库连接成功!

选择操作:

1. 查询

2. 插入

3. 更新

4. 删除

5. 退出

请输入您的选择 (1-5):

这里我先执行1操作,看输出结果。

执行2操作,看输出结果。

可以看到现在我们再次执行1操作查询时,已经比之前多出了一行数据,即(21, '忆梦_怀思', 39)。这个基于我数据库信息任意填写插入的一行信息,也可以改成其他的数据内容进行sql插入。

回到Navicat for MySQL,刷新一下刚才执行操作的数据库,可以看到现在数据库的信息内容更新了,就是多出的刚插入的那行信息内容。

这里还有一点需要强调一下,每次数据库进行刷新后,python是都要重新执行,并再次连接到数据库的。

执行3操作,看输出结果。

再次查看数据库内容,发现原本的(8, '怀思忆梦', 42)变为了现在的(8, '怀思_忆梦', 57),数据进行了更新。

再次刷新一下MySQL,可以看到里面的内容也进行了相应的更新操作。

执行4操作,看输出结果。

可以很明确的看到执行删除操作前后数据的变化,执行操作把(5, '怀思', 28)这行数据进行了删除。

同样再次刷新一下MySQL,可以看到里面的内容也进行了相应的删除操作。

最后执行5操作,就是直接退出连接数据库的意思。

这样我们就实现了利用python代码对于数据库的查询、插入、更新、删除等操作。

b. 动态实现sql语句操作的python代码:
#动态实现sql语句操作import mysql.connector  # 导入MySQL连接器模块
from mysql.connector import Error# 函数:连接到数据库
def connect_to_database(host, user, password, database):try:# 尝试连接到数据库connection = mysql.connector.connect(host=host, user=user, password=password, database=database)  # 使用给定的参数建立连接print("数据库连接成功!")  # 打印连接成功消息return connection  # 返回连接对象except Error as e:  # 捕获可能的错误print("数据库连接失败:", e)  # 打印连接失败消息return None  # 如果连接失败,返回空值# 函数:执行查询或修改
def run_query(connection, query):cursor = connection.cursor()  # 创建游标对象try:cursor.execute(query)  # 执行传入的SQL查询if query.lower().startswith("select"):  # 如果是SELECT查询return cursor.fetchall()  # 返回查询结果集else:  # 对于其他类型的查询(INSERT、UPDATE、DELETE等)connection.commit()  # 提交修改return cursor.rowcount  # 返回受影响的行数except Error as e:  # 捕获可能的错误print("SQL错误:", e)  # 打印SQL错误消息return None  # 返回空值finally:cursor.close()  # 最终关闭游标# 主函数
def main():host = input("请输入主机地址: ")  # 获取主机地址user = input("请输入用户名: ")  # 获取用户名password = input("请输入密码: ")  # 获取密码database = input("请输入数据库名称: ")  # 获取数据库名称connection = connect_to_database(host, user, password, database)  # 连接到数据库if connection is None:  # 如果连接失败,结束程序returnwhile True:print("\n选择操作:") # query = 右侧字符串的内容才是举例的sql执行语句print("1. 查询") # query = "SELECT * FROM view;"print("2. 插入") # query = "INSERT INTO view (id, name, count) VALUES (xx, 'xxx', xx);"print("3. 更新") # query = "UPDATE view SET name = 'xxx', count = xx WHERE id = xx;"print("4. 删除") # query = "DELETE FROM view WHERE id = xx;"print("5. 退出")choice = input("请输入您的选择 (1-5): ")  # 获取用户选择if choice in ["1", "2", "3", "4"]:  # 如果选择为1至4之间的数字query = input("请输入SQL语句: ")  # 获取用户输入的SQL语句result = run_query(connection, query)  # 执行用户输入的SQL语句if result is not None:  # 如果执行成功if isinstance(result, list):  # 如果返回的是查询结果集for row in result:  # 遍历结果并打印print(row)else:  # 对于INSERT、UPDATE、DELETE等操作if result > 0:print("操作成功,影响行数:", result)  # 打印受影响的行数else:print("操作失败,影响行数:", result)  # 打印受影响的行数else:print("请检查您的SQL语句并重试。")  # 如果SQL执行失败,提示用户检查语句elif choice == "5":  # 如果选择为5,退出程序breakelse:print("无效的选择,请输入1-5之间的数字。")  # 如果选择无效,提示用户重新输入if connection.is_connected():  # 如果数据库连接仍然处于打开状态connection.close()  # 关闭数据库连接if __name__ == "__main__":main()  # 运行主函数

执行1操作,这里就不是像静态那样直接输入选择就能执行sql指令的,需要自己输入对应的sql语句才能进行相应的操作。比如我输入SELECT * FROM view;

可以看到数据库信息的返回显示。

执行2操作,输入INSERT INTO view (id, name, count) VALUES (50, '怀思_hs', 78);

进行插入操作,成功添加数据(50, '怀思_hs', 78)。

返回MySQL查看当前的信息内容的变化,记录已成功添加。

执行2操作,输入UPDATE view SET name = '忆梦_ym', count = 100 WHERE id = 1;

数据已从(1, '忆梦', 15)更新为(1, '忆梦_ym', 100)

返回MySQL查看当前的信息内容的变化,记录已成功更新。

执行4操作,输入DELETE FROM view WHERE id = 21;

数据(21, '忆梦_怀思', 39)已被成功删除。

返回MySQL查看当前的信息内容的变化,记录已成功删除。

执行操作5,退出进程,断开和MySQL的连接。

以上就是关于python代码连接MySQL数据库并执行相关sql操作的全部内容。演示不易,内容可能有点多,不知道大家能不能看完,希望能给个点赞支持一下,嘿嘿。同时也欢迎大家进行讨论!

相关文章:

利用python连接MySQL数据库并执行相关sql操作

一、新建MySQL数据库 1.启动MySQL服务 打开phpstudy,开启MySQL服务。如果开启失败的话,可以打开任务管理器,把正在运行的mysqld服务的进程进行关闭,再次打开MySQL服务即可启动。 2.新建MySQL数据库 选择数据库,点击…...

jenkins配置

branch: "dev" 切换分支 $WORKSPACE: /var/lib/jenkins/workspace/jenkins任务名 dest_passwd服务器密码 变量 sudo sshpass -p $dest_passwd ssh root192.168.211.319 -tt rm -rf /data/patent/*:删除文件/data/patent/* sudo sshpa…...

LeNet对MNIST 数据集中的图像进行分类--keras实现

我们将训练一个卷积神经网络来对 MNIST 数据库中的图像进行分类,可以与前面所提到的CNN实现对比CNN对 MNIST 数据库中的图像进行分类-CSDN博客 加载 MNIST 数据库 MNIST 是机器学习领域最著名的数据集之一。 它有 70,000 张手写数字图像 - 下载非常简单 - 图像尺…...

Django的回顾的第4天

1.模型层 1.1简介 你可能已经注意到我们在例子视图中返回文本的方式有点特别。 也就是说&#xff0c;HTML被直接硬编码在 Python代码之中。 def current_datetime(request):now datetime.datetime.now()html "<html><body>It is now %s.</body><…...

点云从入门到精通技术详解100篇-基于三维点云的工件曲面轮廓检测与机器人打磨轨迹规划(中)

目录 2.2.2 散乱点云滤波去噪 2.2.3 海量点云数据压缩 2.3 点云采集与预处理实验...

Mapper文件夹在resource目录下但是网页报错找不到productMapper.xml文件的解决

报错如下&#xff1a; 我的Mapper文件夹在resourse目录下但是网页报错找不到productMapper.xml。 结构如下&#xff1a;代码如下&#xff1a;<mappers><mapper resource"com/dhu/mapper/productMapper.xml" /> </mappers> 这段代码是在mybatis-co…...

22.Oracle中的临时表空间

Oracle中的临时表空间 一、临时表空间概述1、什么是临时表空间2、临时表空间的作用 二、临时表空间相关语法三、具体使用案例1、具体使用场景示例2、具体使用场景代码示例 点击此处跳转下一节&#xff1a;23.Oracle11g的UNDO表空间点击此处跳转上一节&#xff1a;21.Oracle的程…...

附录A 指令集基本原理

1. 引言 本书主要关注指令集体系结构4个主题&#xff1a; 1. 提出对指令集进行分类的方法&#xff0c;并对各种方法的优缺点进行定性评估&#xff1b; 2. 提出并分析一些在很大程度上独立于特定指令集的指令集评估数据。 3. 讨论语言与编译器议题以及…...

Unittest单元测试之unittest用例执行顺序

unittest用例执行顺序 当在一个测试类或多个测试模块下&#xff0c;用例数量较多时&#xff0c;unittest在执行用例 &#xff08;test_xxx&#xff09;时&#xff0c;并不是按从上到下的顺序执行&#xff0c;有特定的顺序。 unittest框架默认根据ACSII码的顺序加载测试用例&a…...

海云安谢朝海:开发安全领域大模型新实践 人工智能助力高效安全左移

2023年11月29日&#xff0c;2023中国&#xff08;深圳&#xff09;金融科技大会成功举行&#xff0c;该会议是深圳连续举办的第七届金融科技主题年度会议&#xff0c;也是2023深圳国际金融科技节重要活动之一。做好金融工作&#xff0c;需要兼顾创新与安全&#xff0c;当智能体…...

Postman接口测试工具完整教程

前言 作为软件开发过程中一个非常重要的环节&#xff0c;软件测试越来越成为软件开发商和用户关注的焦点。完善的测试是软件质量的保证&#xff0c;因此软件测试就成了一项重要而艰巨的工作。要做好这项工作当然也绝非易事。 第一部分&#xff1a;基础篇 postman:4.5.1 1.安…...

Android 滑动按钮(开关) SwitchCompat 自定义风格

原生的SwitchCompat控件如下图&#xff0c;不说不堪入目&#xff0c;也算是不敢恭维了。开个玩笑... 所以我们就需要对SwitchCompat进行自定义风格&#xff0c;效果如下图 代码如下 <androidx.appcompat.widget.SwitchCompatandroid:id"id/switch_compat"android:…...

前端面试灵魂提问-计网(2)

1、websocket 为什么全双工? 1.1 WebSocket是什么 WebSocket 是一种通信协议&#xff0c;它在客户端和服务器之间建立持久的全双工连接。全双工意味着数据可以双向流动&#xff0c;即客户端可以向服务器发送消息&#xff0c;服务器也可以向客户端发送消息&#xff0c;而无需…...

Git修改远程仓库名称

1、先直接在远程点仓库名&#xff0c;然后左侧菜单栏找settings-general&#xff0c;然后直接修改工程名&#xff0c;保存即可。 2、还是在settings-general下&#xff0c;下拉找到Advanced点击Expand展开&#xff0c;然后下拉到最底部 在Change path里填入新的项目名称&#x…...

kafka 集群 ZooKeeper 模式搭建

Apache Kafka是一个开源分布式事件流平台&#xff0c;被数千家公司用于高性能数据管道、流分析、数据集成和关键任务应用程序 Kafka 官网&#xff1a;Apache Kafka 关于ZooKeeper的弃用 根据 Kafka官网信息&#xff0c;随着Apache Kafka 3.5版本的发布&#xff0c;Zookeeper现…...

【LeetCode】 160. 相交链表

相交链表 题目题解 题目 给你两个单链表的头节点 headA 和 headB &#xff0c;请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点&#xff0c;返回 null 。 图示两个链表在节点 c1 开始相交&#xff1a; 题目数据 保证 整个链式结构中不存在环。 注意&am…...

TZOJ 1429 小明A+B

答案&#xff1a; #include <stdio.h> int main() {int T0, A0, B0, sum0;scanf("%d", &T); //输入测试数据的组数while (T--) //循环T次{scanf("%d %d", &A, &B); //输入AB的值sum A B;if (sum > 100) //如果是三位数{…...

制作openeuler的livecd

下载该项目&#xff0c;执行下面的操作gitee openeuler livecd项目 基于openeuler环境 #安装工具&#xff0c;第一次可能报错&#xff0c;可以再执行一次 make installx86 livecd-creator -d -v --config./config/euler_x86_64.ks --fslabeleuler-LiveCD --cachecache --log…...

B.牛牛排队伍——模拟双链表

当前位置: 首页 > news >正文 B.牛牛排队伍——模拟双链表 news 2023/12/1 15:14:37 分析 题目其实很简单,就是双链表的增删查,但是刚开始,直接vis标记删除元素,查找一个位置的前一个用的while不断向前找,但是TLE;毕竟O(n*k)的复杂度,一开始没有考虑时间复杂度…...

【PyTorch】(四)损失函数与优化器

文章目录 1. 损失函数2. 优化器 1. 损失函数 2. 优化器...

12.找到字符串中所有字母异位词

&#x1f9e0; 题目解析 题目描述&#xff1a; 给定两个字符串 s 和 p&#xff0c;找出 s 中所有 p 的字母异位词的起始索引。 返回的答案以数组形式表示。 字母异位词定义&#xff1a; 若两个字符串包含的字符种类和出现次数完全相同&#xff0c;顺序无所谓&#xff0c;则互为…...

初探Service服务发现机制

1.Service简介 Service是将运行在一组Pod上的应用程序发布为网络服务的抽象方法。 主要功能&#xff1a;服务发现和负载均衡。 Service类型的包括ClusterIP类型、NodePort类型、LoadBalancer类型、ExternalName类型 2.Endpoints简介 Endpoints是一种Kubernetes资源&#xf…...

vulnyx Blogger writeup

信息收集 arp-scan nmap 获取userFlag 上web看看 一个默认的页面&#xff0c;gobuster扫一下目录 可以看到扫出的目录中得到了一个有价值的目录/wordpress&#xff0c;说明目标所使用的cms是wordpress&#xff0c;访问http://192.168.43.213/wordpress/然后查看源码能看到 这…...

08. C#入门系列【类的基本概念】:开启编程世界的奇妙冒险

C#入门系列【类的基本概念】&#xff1a;开启编程世界的奇妙冒险 嘿&#xff0c;各位编程小白探险家&#xff01;欢迎来到 C# 的奇幻大陆&#xff01;今天咱们要深入探索这片大陆上至关重要的 “建筑”—— 类&#xff01;别害怕&#xff0c;跟着我&#xff0c;保准让你轻松搞…...

解读《网络安全法》最新修订,把握网络安全新趋势

《网络安全法》自2017年施行以来&#xff0c;在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂&#xff0c;网络攻击、数据泄露等事件频发&#xff0c;现行法律已难以完全适应新的风险挑战。 2025年3月28日&#xff0c;国家网信办会同相关部门起草了《网络安全…...

逻辑回归暴力训练预测金融欺诈

简述 「使用逻辑回归暴力预测金融欺诈&#xff0c;并不断增加特征维度持续测试」的做法&#xff0c;体现了一种逐步建模与迭代验证的实验思路&#xff0c;在金融欺诈检测中非常有价值&#xff0c;本文作为一篇回顾性记录了早年间公司给某行做反欺诈预测用到的技术和思路。百度…...

保姆级【快数学会Android端“动画“】+ 实现补间动画和逐帧动画!!!

目录 补间动画 1.创建资源文件夹 2.设置文件夹类型 3.创建.xml文件 4.样式设计 5.动画设置 6.动画的实现 内容拓展 7.在原基础上继续添加.xml文件 8.xml代码编写 (1)rotate_anim (2)scale_anim (3)translate_anim 9.MainActivity.java代码汇总 10.效果展示 逐帧…...

uni-app学习笔记三十五--扩展组件的安装和使用

由于内置组件不能满足日常开发需要&#xff0c;uniapp官方也提供了众多的扩展组件供我们使用。由于不是内置组件&#xff0c;需要安装才能使用。 一、安装扩展插件 安装方法&#xff1a; 1.访问uniapp官方文档组件部分&#xff1a;组件使用的入门教程 | uni-app官网 点击左侧…...

结构化文件管理实战:实现目录自动创建与归类

手动操作容易因疲劳或疏忽导致命名错误、路径混乱等问题&#xff0c;进而引发后续程序异常。使用工具进行标准化操作&#xff0c;能有效降低出错概率。 需要快速整理大量文件的技术用户而言&#xff0c;这款工具提供了一种轻便高效的解决方案。程序体积仅有 156KB&#xff0c;…...

Copilot for Xcode (iOS的 AI辅助编程)

Copilot for Xcode 简介Copilot下载与安装 体验环境要求下载最新的安装包安装登录系统权限设置 AI辅助编程生成注释代码补全简单需求代码生成辅助编程行间代码生成注释联想 代码生成 总结 简介 尝试使用了Copilot&#xff0c;它能根据上下文补全代码&#xff0c;快速生成常用…...