暑期实习总结(焊点数据管理软件开发):Python操作MySQL数据库、Django搭建前端网页、以及Excel中数据与MySQL数据库的互转

news2025/1/22 7:59:52

暑期实习总结(焊点数据管理软件开发):Python操作MySQL数据库、Django搭建前端网页、以及Excel中数据与MySQL数据库的互转

​ 这一周是我在企业实习的最后一周,在企业做的项目已基本完成。这篇博客的目的也是总结一些项目中的一些小问题,和相关功能的代码总结。

​ 这个项目呢,由于企业的保密性,我并不能在此做一个完整的分享。但我可以做一些简单的介绍,记录我认为的一些技术要点。我在自己的简历中更新的该项目的介绍内容如下:

焊点数据管理软件开发:使用Python语言、MySQL数据库、Django框架开发了一个数据管理软件。使用Django搭建前端网页,使用Python语言处理大量焊点数据集并操作MySQL数据库,完成了智能车间质量二环中焊点数据从Excel到MySQL数据库的整合与存储,以及从MySQL数据库导出为Excel表数据的功能。

​ 主要包含的关键点我认为有以下三个:Python操作数据库、Django搭建前端网页、以及Excel中数据与MySQL数据库的互转。

​ 下面我将介绍一些相关功能样例代码:

连接数据库&使用Python操作数据库

在本项目中,我使用的是pymysql包来连接数据库的。个人感觉这个方法用起来非常方便。这个方法可以直接转译Mysql语言,这对于本身就有Mysql数据库的技术基础的友友来说非常方便。以下案例中,各位可以了解到我以上提到的点。

连接数据库:
def mysql_connection_A():
    # 打开数据库连接
    try:
        global db
        db = pymysql.connect(host='localhost', user='root', passwd='xxxxxx', port=3306)# passwd为用户安装mysql时设置的数据库密码
        print('连接成功!')
    except:
        print('something wrong!')

    # 使用 cursor() 方法创建一个游标对象 cursor
    global cursor
    cursor = db.cursor()
    sql = """use a_shift;
        """# 这里直接转译mysql语句,将操作链接到a_shift这个数据库
    cursor.execute(sql)

    return cursor

该方法用途非常广泛,定义一个变量db来连接数据库,并通过创建一个游标对象来操作数据库。好处就是,用户在mysql中使用的所有sql语句都可以直接在python中完成。比如以上的“use a_shift”就是一段sql语句。

如果还不明白我的意思的话,下面给出一段代码,相信大家会有更深的了解:

sql1 = """DROP TABLE IF EXISTS {table_name}""".format(table_name=table_name)
cursor.execute(sql1)
sql2 = """create table {table_name}(id int primary key auto_increment, weld_num char(8), attr char(16))""".format(table_name=table_name)
cursor.execute(sql2)

# 用于存取/提交数据到数据库的一个函数
def data_commit_sql(query1, values):
     # query:插入数据的sql语句;values:对应的数据库格式的值
     # 存取数据
     cursor.execute(query1, values)
     db.commit()
    
data_commit_sql("INSERT INTO {table_name}(weld_num,attr) VALUES (%s, %s)".format(table_name=table_name), (weld_value, '厚度'))

首先可以看到sql1和sql2两个语句。两者都是sql语句,只不过其中的变量通过format方法给提取出来了。sql1语句的意思如果这个表存在的话,删除该表;sql2语句的意思就是创建一个指定格式的表。由此我们可以知道,通过这样的方法,我们完全能够用python结合简单的sql语句,直接操作数据库,而不需要在数据库中输入任何操作命令。并且其中的变量还能提取出来,从其他途径来获取。

然后就是data_commit_sql(query1, values)这个函数。这个函数实则就是一个游标获取语句和提交数据打包的一个函数。只是由于后面相同的操作太多,我才给他定义的这样一个函数。可以看到函数定义下面的一个例子,insert这个语句。这个语句意思就是在表中插入一些数据。而这个数据是通过values(%s,%s)链接出来的。例子中,第一个%s就对应的weld_value这个变量,第二个%s就对应的’厚度’这个字符串。

所以在pymysql方法的相关操作中,除了最基本的语言方法之外。我们可以通过format()方法和values(%s,)的方法来定义外部变量,从而完成用python操作mysql数据库的相关操作。

Django搭建前端网页

这个网页的搭建方法和教程啥的我这里就不用多说了。具体可以参考我之前的博客,或者去b站看教程:

Django学习记录:初步认识django以及实现了简单的网页登录页面的前后端开发_dumpling0120的博客-CSDN博客

Django学习记录:使用ORM操作MySQL数据库并完成数据的增删改查_dumpling0120的博客-CSDN博客

2022 B站最详细django3教程(django从入门到实践)_哔哩哔哩_bilibili

这里提几个功能简单介绍一下。

form表的使用:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

<h1>用户登录</h1>
<form method="post" action = "/login/">

    {% csrf_token %}

    <input type = "text" name = "user" placeholder="用户名">
    <input type = "password" name = "pwd" placeholder="密码">
    <input type = "submit" value="提交">
    <span style="color:red;"> {{ error_msg }}</span>

</form>

</body>
</html>

这个也是上面有一期博客中已经提到过的登录界面的代码。在这里我想讲的就是,form表的相关使用可以推广。三种类型“text”代表可视化字符,“password”代表不可见的字符(密码),“submit”就是一个提交的跳转按钮。然后使用的时候需要加上{% csrf_token %},不然会报错。

按钮跳转:

1、跳转到某网页:

// 设置按钮
<button οnclick="location.href='{% url 'A_shift' %}'">A班</button>
<button οnclick="location.href='{% url 'B_shift' %}'">B班</button>

注意这个url需要跳转的网页的地址是需要在urls.py这个文件中定义的:

path('pymysql_testA/', views.pymysql_testA, name='A_shift'),
path('pymysql_testB/', views.pymysql_testB, name='B_shift'),

2、点击按钮后实现某些操作:

<button id="showTablesButtonA">A班</button>

<script src={% static 'js/jquery-3.6.0.min.js' %}></script>
<script>
 $(document).ready(function() {
    $('#showTablesButtonA').click(function() {
      // 发起 Ajax 请求获取表数据
      $.ajax({
          url: '/get_tables_A/',  // 表格的路由地址
          type: 'GET',
          data: {'is_button_pressed_A': 'true'},
          success: function(response) {
          // 在按钮下方显示表数据
              $('#tableData').html('<h3>A班数据表总览</h3>' + response);
              // 发送表存在状态到后端
               $('#is_A_table_generated').val('true');  // 设置隐藏字段的值
                 $.ajax({
                            url: '/database_to_excel/',
                            type: 'POST',
                            data: {'is_A_table_generated': $('#is_A_table_generated').val()},
                            success: function(response) {
                                // 处理成功响应
                            }
                 });
          }
      });
    });
 });
</script>

这段代码是引入jquery包后的一段JavaScript语言编写的一个按钮响应事件,实现的功能则是如下:

在这里插入图片描述
点击A班/B班按钮,则可以从数据库中提取并查看A班/B班数据库中的数据总列表,展示在网页中。具体代码示例就是上面的例子。其中上面有个这个:$(‘#is_A_table_generated’).val(‘true’); // 设置隐藏字段的值。这里是一个关键,是我作为后续模块中的一个参数的开关,这个隐藏字段在下面的代码起到了传值的作用。不知道我这么解释大家看得懂不hhh。

<h2>请选择您想导出的数据表和存储路径</h2>
<h4>*数据表名请从原数据库表中复制;存储路径格式举例:D:\PyCharm\file2.xls</h4>
<form method="post" action = "/database_to_excel/">

    {% csrf_token %}
    <input type="hidden" id="is_A_table_generated" name="is_A_table_generated" value="">
    <input type="hidden" id="is_B_table_generated" name="is_B_table_generated" value="">
    <input type = "text" name = "database_name" placeholder="数据表名">
    <input type = "text" name = "storage_path" placeholder="存储路径">
    <button type="submit">提交</button>

</form>

由于本人不太懂JavaScript,故这里不再多赘述。想了解这方面知识的友友可以自行查看相关资料,或私信与我交流。

Excel中数据与MySQL数据库的互转

从excel中将数据传入MySQL中,这个demo其实在第一个大点“连接数据库&使用Python操作数据库”有所涉及。不过我这里还是总结性的讲一下我的一个思路吧。

主要采用的还是下面几个包:

import pandas as pd
import xlwt
import xlrd

下面我就分别讲一下两者互传数据的思路。

从excel中提取数据并存入MySQL

pandas则是用来读取excel数据,然后xlwt和xlrd这两个包则是用来处理表中的值。以下举个简单例子:

excel_data = pd.read_excel(source_file_path_1)
# 提取检测后数据
detect_data = excel_data.iloc[0, 12]
# 提取好的产品数据
good_pro_data = excel_data.iloc[1, 12]

这就是简单的一个pandas读取这个路径下excel表中的值,并将表中相关数据提取出来。然后使用上文提到的data_commit_sql(query1, values)函数将这两个值传进数据库中即可。

从MySQL中提取数据表并存入Excel

由于提取的表格式是不需要改变的,所以这个点我写了一个完整的函数。

def export_to_excel(cursor, table, save_path):
    """
    cursor:     源数据的数据库游标,用于数据库连接
    table       源数据的数据表,指定需要转换的数据库表
    save_path       文件保存路径,指定文件保存的位置和excel文档的名字
    """
    # 创建保存数据库的excel表
    workbook = xlwt.Workbook()
    worksheet = workbook.add_sheet("sheet1")

    # 首先向excel表中写入数据表的字段
    column_count = cursor.execute("desc %s"%table)
    for i in range(column_count):
       temptuple = cursor.fetchone()
       worksheet.write(0, i, temptuple[0])

    # 向构建好字段的excel表写入所有的数据记录
    row_count = cursor.execute("select * from %s"%table)
    for i in range(row_count):
        temptuple = cursor.fetchone()
        for j in range(column_count):
            worksheet.write(i + 1, j, temptuple[j])

    # 指定路径并保存
    workbook.save(save_path)
    print('文件转换成功')
    
# 应用举例    
export_to_excel(cursorA, '{database_name}'.format(database_name=database_name), r"{storage_path}".format(storage_path=storage_path))

注释中也将相关方法说明得很详细了。在使用中调用该函数export_to_excel(cursor, table, save_path)的时候需要注意下相关格式就好。需要注意的是table表名和save_path的格式。table表名字的话建议format一下,然后路径也是建议加个r,防止路径格式报错。


总结

​ 博主本科机械,研究生做控制。这次在车企实习呢,实习内容又是做数据处理以及相关的前后端开发。虽然看上去毫不沾边,但如果能用两个月的时间多学一个技术栈,想想也是极好的。毕竟有目的性地学习,我认为是可以大大提高我的学习效率。况且在这个信息化的时代,这样类似的数据管理系统,几乎每个企业都是有这样的需求并且能够用得上的。所以,我也是非常感谢这样的机会,让我能够了解企业,真实了解并参与企业的相关项目!

​ 感谢你能看到最后,希望我能与大家多多交流技术,一起进步,一起成长!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/943039.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

经典文献阅读之--MobileSAM(比FastSAM更快的SAM框架)

0. 简介 自从MetaAI提出的能够“分割一切”的视觉基础大模型SAM提供了很好的分割效果&#xff0c;为探索视觉大模型提供了一个新的方向。虽然SAM的效果很好&#xff0c;但由于SAM的backbone使用了ViT&#xff0c;导致推理时显存的占用较多&#xff0c;推理速度偏慢&#xff0c…

大数据学习:hive的DQL和DML操作

hive的DQL和DML操作 1. Hive的分桶表 1.1 分桶表原理 分桶是相对分区进行更细粒度的划分 Hive表或分区表可进一步的分桶 分桶将整个数据内容按照某列取hash值&#xff0c;对桶的个数取模的方式决定该条记录存放在哪个桶当中&#xff1b;具有相同hash值的数据进入到同一个文件…

4、监测数据采集物联网应用开发步骤(4)

监测数据采集物联网应用开发步骤(3) 日志或文本文件读写开发 创建全局变量配置代码com.zxy.common.Com_Para.py全局变量根据需要后续补充。 #! python3 # -*- coding: utf-8 -Created on 2023年08月28日 author: zxyong 13738196011#监测数据采集物联网应用--全局变量 impor…

文件名翻译不求人:一键批量翻译,你就是改名专家

文件名翻译不求人&#xff1a;一键批量翻译&#xff0c;你就是改名专家 在日常生活和工作中&#xff0c;我们常常需要处理各种文件&#xff0c;包括文档、图片、视频等。有时候&#xff0c;我们需要对这些文件进行重命名&#xff0c;以便更好地管理和查找。但是&#xff0c;当…

微服务之Nacos

1 版本说明 官网地址&#xff1a; https://github.com/alibaba/spring-cloud-alibaba/wiki/%E7%89%88%E6%9C%AC%E8%AF%B4%E6%98%8E 1.1 2021.x 分支 适配 SpringBoot 2.4, Spring Cloud 2021.x 版本及以上的Spring Cloud Alibaba 版本如下表&#xff08;最新版本用*标记&am…

Android实现监听APP启动、前台和后台

Android 实时监听APP进入前台或后台 前言 在我们开发的过程中&#xff0c;经常会遇到需要我们判断app进入后台&#xff0c;或者切换到前台的情况。比如我们想判断app切换到前台时&#xff0c;显示一个解锁界面&#xff0c;要求用户输入解锁密码才能继续进行操作&#xff1b;我…

pdf怎么转换成jpg图片?这几个方法值得一试

pdf怎么转换成jpg图片&#xff1f;PDF格式的文件在我们的日常生活和工作中十分常见&#xff0c;但有时候我们需要将PDF文件转换成图片格式&#xff0c;以便于在网页上进行展示或者存放到手机相册中。那么&#xff0c;PDF怎么转换成JPG图片呢&#xff1f;下面介绍几种方法。 第一…

Java【手撕滑动窗口】LeetCode 209. “长度最小子数组“, 图文详解思路分析 + 代码

文章目录 前言一、长度最小子数组1, 题目2, 思路分析3, 代码 前言 各位读者好, 我是小陈, 这是我的个人主页, 希望我的专栏能够帮助到你: &#x1f4d5; JavaSE基础: 基础语法, 类和对象, 封装继承多态, 接口, 综合小练习图书管理系统等 &#x1f4d7; Java数据结构: 顺序表, 链…

达梦数据配置兼容

修改数据库实例的dm.ini配置文件COMPATIBLE_MODE的值&#xff0c;0:none, 1:SQL92, 2:Oracle, 3:MS SQL Server, 4:MySQL, 5:DM6, 6:Teradata, 7:PG COMPATIBLE_MODE 4 #Server compatible mode, 0:none, 1:SQL92, 2:Oracle, 3:MS SQL Server,…

如何设置让软件开机自启动

电脑重置&#xff0c;一些软件能正常使用&#xff0c;但是系统开机自启动选项中并没有它&#xff0c;这就很郁闷 有些极简软件没有直接设置开机自启&#xff0c;需要手动设置&#xff0c;所以我们就需要手动去设置一下它。 1、如果你在任务管理器里能找到它&#xff0c;也可以…

怎么把m4a转换成mp3?音频格式转换方法分享

M4A格式音频文件通常比MP3格式音频文件具有更高的音质&#xff0c;因为它使用了先进的编码技术。但是&#xff0c;M4A文件在某些设备上可能无法播放。将M4A文件转换为MP3格式可以增加音频文件的兼容性&#xff0c;并使其可以在更广泛的设备上播放&#xff0c;如移动设备和汽车音…

解决 git clone 时出现Failed to connect to 127.0.0.1 port 1573问题

今天去拉一个仓库代码&#xff0c;往常都是一下就拉下来了&#xff0c;今天却报错&#xff0c;报错信息如下&#xff1a; 原因&#xff1a;这种情况是因为代理在git中配置的&#xff0c;但是本身环境就有SSL协议了&#xff0c;所以取消git的https或者http代理即可 方法如下&…

文件夹无法删除?简单3招,轻松解决问题!

“我电脑里有一个文件夹占用了很大的内存&#xff0c;我想将它删除来释放一些内存&#xff0c;但是根本没法删除&#xff0c;为什么会这样呢&#xff1f;文件夹无法删除应该怎么办呢&#xff1f;” 在日常电脑使用中&#xff0c;有时候会遇到文件夹无法删除的情况&#xff0c;这…

iTween安装

1. 找到Package Manager面板&#xff0c;Packages选择MyAssets-右上角搜索iTween-找到后点DownLoad-点Import 导入 2. 导入后Assets面板结构如下图。 3. 编译器中输入iTween有提示&#xff0c;安装成功。

DataFrame.plot函数详解(六)

DataFrame.plot函数详解&#xff08;六&#xff09; 使用subplot()做子图&#xff0c;定位每一个子图&#xff0c;设置数据和图形&#xff0c;理解fig和ax(axs)的意义和作用。 1. subplot() matplotlib.pyplot.subplots(nrows1, ncols1, *, sharexFalse, shareyFalse, squee…

Spring Boot框架以及它的优势

文章目录 介绍1. **简化配置**2. **快速启动**3. **自动配置**4. **集成第三方库和框架**5. **微服务支持**6. **内嵌式数据库支持**7. **健康监控和管理**8. **可插拔的开发工具**9. **丰富的社区和生态系统**10. **良好的测试支持&#xff1a;** 核心特性**1. 依赖注入&#…

解决Python中的循环引用和内存泄漏问题

在Python编程中&#xff0c;循环引用和内存泄漏是两个常见的问题。本文将详细介绍如何识别和解决这些问题&#xff0c;并提供详细的代码示例。 1、什么是循环引用&#xff1f; 循环引用是指两个或多个对象之间相互引用的情况。这种情况可能导致内存泄漏&#xff0c;因为Python…

无涯教程-Android - 环境设置

您可以从Oracle的Java网站下载最新版本的Java JDK-Java SE下载&#xff0c;您将在下载的文件中找到有关安装JDK的说明,按照给定的说明安装和配置安装程序。最后,将PATH和JAVA_HOME环境变量设置为引用包含 java 和 javac 的目录,通常分别是java_install_dir/bin和java_install_d…

QML Book 学习基础3(动画)

目录 主要动画元素 例子&#xff1a; 非线性动画 分组动画 Qt 动画是一种在 Qt 框架下创建交互式和引人入胜的图形用户界面的方法&#xff0c;我们可以认为是对某个基础元素的多个设置 主要动画元素 PropertyAnimation-属性值变化时的动画 NumberA…