百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Qt for Python—可视化开发GUI应用程序

off999 2024-10-18 08:09 21 浏览 0 评论

前言

本系列第三篇文章(Qt for Python学习笔记—应用程序初探 )、第四篇文章(Qt for Python学习笔记—应用程序再探 )中均是使用纯代码方式来开发 PySide6 GUI 应用程序的。

本系列第五篇文章(Qt for Python—Qt Designer 概览 )介绍了可视化界面设计工具——Qt Designer

本文是本系列第六篇文章,将对如何借助 Qt Designer 工具进行可视化界面设计并完成一个 PySide6 GUI 应用程序开发的过程进行介绍。



1. 简介

借助 Qt Designer 工具进行可视化界面设计,进而完成一个 PySide6 GUI 应用程序开发的基本过程大致如下:

(1) 确定应用程序开发目标及原型;

(2) 借助 Qt Designer 工具可视化地设计窗体(保存为 .ui 文件);

(3) 利用工具将窗体文件编译转换成窗体 Python 程序文件 .py 文件));

(4) 对转换成的窗体 Python 程序文件加以完善;

(5) 应用完善后的窗体 Python 程序文件

注:本示例工作目录为 C:\MyPySide6


下面我们将再次实现本系列第四篇文章(Qt for Python学习笔记—应用程序再探 )中的示例程序。



2. 示例目标及原型

我们确定该示例程序所设想达到的目标,并给出其原型。

一、示例目标:

本示例目标是创建一个 Python GUI 应用程序,其主窗口标题为“PySide6 示例程序”,其右上角有最小化、最大化和关闭按钮,窗口可拉伸。其主窗体中分为上下两个区域:

(一)上面是放置一个行编辑器(QLineEdit):

(1) 缺省显示文本内容为 “借助 Qt Designer 完成的 PySide6 GUI 应用程序!”

(2) 文本居中对齐,字体设置为蓝色,粗体,13px;

(二)下面放置一排4个按钮(QPushButton),依次为:

(1) 【改色】按钮:点击按钮后,文本字体显示为红色

(2) 【恢复】按钮:点击按钮后,文本字体显示为蓝色

(3) 【清除】按钮:点击按钮后,文本内容清空

(4) 【关闭】按钮:点击按钮后,关闭窗口退出程序


二、示例原型:

在进行 GUI 应用程序编码之前,一般建议先勾画出 GUI 框架(窗体及各部件的布局等)。本示例原型如下:



3. Qt Designer 设计窗体

3.1 基本步骤

使用 Qt Designer 工具可视化进行窗体设计大致分为如下几个基本步骤:

(1) 启动 Qt Designer 工具,创建一个窗体(选择所需的窗体模板类型)

(2) 从左侧的【窗口部件盒】拖曳部件到窗体中进行放置

(3) 通过【属性编辑器】完成各部件属性的设置

(4) 对窗体上各部件进行布局设置

(5) 通过【信号/槽 编辑器】完成相关部件信号/槽的连接

(6) 对设计好的窗体进行预览

(7) 将设计好的窗体保存为窗体文件


3.2 创建一个窗体(Form)

单击桌面上的 Qt Designer 快捷方式,然后启动 Qt Designer

Qt Designer 窗口出现后,通常会自动弹出一个【新建窗体】的对话框窗口(如下图示),在该窗口中选择一个窗体模板(如:Main Window)。

注:或者在 Qt Designer 窗口中通过快捷键 Ctrl+N 或者点击主菜单【文件】下的【新建…】菜单项,弹出【新建窗体】对话框。

然后点击对话框底部的【创建】按钮,即可进入 Qt Designer 设计窗口(如下图示):

可以看到在 Qt Designer 设计窗口的中间是尚未命名的“MainWindow”窗体,也就是用于放置各部件的“画布”区域。


3.3 在窗体上放置部件

首先通过快捷键 F3 将窗口切换到【编辑窗口部件】模式。

然后分别从窗口左侧的【窗口部件盒】中的【Input Widgets】分组类别中选择1个 QLineEdit 部件,从【Buttons】分组类别中选择4个 QPushButton 部件,通过鼠标拖拽相关部件到中间的尚未命名的窗体上,并适当调整窗体尺寸,并进行初步的布局设计(如下图示)。


3.4 设置对象属性

接下来,继续在【编辑窗口部件】模式下通过属性编辑器逐一完成对象(窗体和各组件)的属性的设置。

一、窗体中各对象名一览表

注:统一修订好各组件对象名,建议按照一定的规则,有利于后续业务代码编写和维护。


二、窗体中各对象属性值一览表

注:部件的样式可以通过【编辑样式表】对话框进行设置(如下图示):


属性设置完毕后,窗体效果如下图示:


3.5 各部件应用布局

点击窗体空白处,在鼠标右键菜单中,选择【布局】-【栅格布局】菜单项,将窗体上的各部件自动按照网格完成布局。


3.6 建立信号和槽连接

首先通过快捷键 F4 将窗口切换到【编辑信号/槽】模式,然后通过右下侧的【信号/槽编辑器】添加相关信号/槽信息。

本示例程序中4个按钮均需建立起 clicked() 信号和槽信息。其中:

——【清除】按钮的 clicked() 信号对应的是行编辑器的内置的槽函数 clear()

——【关闭】按钮的 clicked() 信号对应的是主窗口的内置的槽函数 close()

——【改色】按钮的 clicked() 信号对应的是行编辑器的自定义槽函数 btnChange_Clicked();因自定义槽函数尚未定义,故在窗体设计环节尚无法建立起信号和槽函数的连接。

——【恢复】按钮的 clicked() 信号对应的是行编辑器的自定义槽函数 btnReset_Clicked();因自定义槽函数尚未定义,故在窗体设计环节尚无法建立起信号和槽函数的连接。


此时窗体发生变化,显示如下:


3.7 预览窗体

窗体设计好后,可以通过快捷键 Ctrl + R 或 点击主菜单项【窗体】下的【预览】子菜单项,对设计好的窗体进行快速预览。

可以试着点击各个按钮,拉伸窗口,看看效果。

注1:因【改色】按钮、【恢复】按钮尚未定义好对应的槽函数,所以这两个按钮点击时暂时还不能进行功能响应;这部分等将窗体文件转换成 Python 程序文件后再进行添加。

注2:因【清除】按钮、【关闭】按钮关联的是 Qt 内置的槽函数,所以这两个按钮点击时会正常进行功能响应。


3.8 保存窗体文件

当确定窗体已经设置完毕后,就可以点击 Qt Designer 工具栏上的【保存】图标按钮(或点击主菜单【文件】下的【保存】子菜单项)将窗体保存为窗体文件(后缀名为: .ui),如:C:\MyPySide6\MyMainWindow.ui

创建完成的窗体文件MyMainWindow.ui )内容参考如下:

 <?xml version="1.0" encoding="UTF-8"?>
 <ui version="4.0">
  <class>MainWindow</class>
  <widget class="QMainWindow" name="MainWindow">
   <property name="geometry">
    <rect>
     <x>0</x>
     <y>0</y>
     <width>416</width>
     <height>158</height>
    </rect>
   </property>
   <property name="windowTitle">
    <string>PySide6 示例程序</string>
   </property>
   <widget class="QWidget" name="centralwidget">
    <layout class="QGridLayout" name="gridLayout">
     <item row="0" column="0" colspan="4">
      <widget class="QLineEdit" name="lineEdit">
       <property name="sizePolicy">
        <sizepolicy hsizetype="Expanding" vsizetype="Fixed">
         <horstretch>0</horstretch>
         <verstretch>0</verstretch>
        </sizepolicy>
       </property>
       <property name="font">
        <font>
         <pointsize>-1</pointsize>
         <italic>false</italic>
         <bold>true</bold>
        </font>
       </property>
       <property name="layoutDirection">
        <enum>Qt::LeftToRight</enum>
       </property>
       <property name="autoFillBackground">
        <bool>false</bool>
       </property>
       <property name="styleSheet">
        <string notr="true">color: blue;
 font: bold; 
 font-size: 13px;</string>
       </property>
       <property name="text">
        <string>借助 Qt Designer 完成的 PySide6 GUI 应用程序!</string>
       </property>
       <property name="alignment">
        <set>Qt::AlignCenter</set>
       </property>
      </widget>
     </item>
     <item row="1" column="0">
      <widget class="QPushButton" name="btnChange">
       <property name="text">
        <string>改色</string>
       </property>
      </widget>
     </item>
     <item row="1" column="1">
      <widget class="QPushButton" name="btnReset">
       <property name="text">
        <string>恢复</string>
       </property>
      </widget>
     </item>
     <item row="1" column="2">
      <widget class="QPushButton" name="btnClear">
       <property name="text">
        <string>清除</string>
       </property>
      </widget>
     </item>
     <item row="1" column="3">
      <widget class="QPushButton" name="btnQuit">
       <property name="text">
        <string>关闭</string>
       </property>
      </widget>
     </item>
    </layout>
   </widget>
  </widget>
  <resources/>
  <connections>
   <connection>
    <sender>btnClear</sender>
    <signal>clicked()</signal>
    <receiver>lineEdit</receiver>
    <slot>clear()</slot>
    <hints>
     <hint type="sourcelabel">
      <x>258</x>
      <y>106</y>
     </hint>
     <hint type="destinationlabel">
      <x>207</x>
      <y>48</y>
     </hint>
    </hints>
   </connection>
   <connection>
    <sender>btnQuit</sender>
    <signal>clicked()</signal>
    <receiver>MainWindow</receiver>
    <slot>close()</slot>
    <hints>
     <hint type="sourcelabel">
      <x>359</x>
      <y>106</y>
     </hint>
     <hint type="destinationlabel">
      <x>207</x>
      <y>78</y>
     </hint>
    </hints>
   </connection>
  </connections>
 </ui>


4.将.ui文件编译转换为.py文件

上面将窗体设计好并保存为窗体文件(如:MyMainWindow.ui)后,如果要在 Python 中使用该窗体,还需要使用编译转换工具(如:pyside6-uic.exe)将窗体文件.ui)编译成对应的窗体 Python 程序文件.py)。

可通过两种方式将窗体文件.ui)转换为窗体 Python 程序文件.py)。


4.1 通过命令方式实现转换

从控制台终端通过命令方式来执行编译转换(通常要先进入窗体文件所在目录 C:\MyPySide6下):

 C:\> cd C:\MyPySide6
 C:\MyPySide6> pyside6-uic.exe -o ui_MyMainWindow.py MyMainWindow.ui

上述第2行命令表示,使用 pyside6-uic.exe 工具将窗体文件MyMainWindow.ui)编译转换成窗体 Python 程序文件ui_MyMainWindow.py)。

注1:为了便于区分正常 Python 文件与窗体 Python 文件,通常会在转换成的窗体 Python 文件名前加个前缀(ui_),这样文件名就变为了:ui_MyMainWindow.py,比较一目了然。

注2: pyside6-uic.exe 的路径在 C:\Devlelop\Python\Scripts 下,而该路径在安装 Python 时已经被添加到了 Windows 的 PATH 环境变量里,故 pyside6-uic.exe 在终端窗口里可以直接运行。

注3:PyQt6 中对应的是:pyuic6.exe 工具,在 C:\Devlelop\Python\Scripts 下。


4.2 通过 Visual Studio Code 的扩展实现转换

本系列第二篇文章(Qt for Python学习笔记—搭建开发环境 )中已经安装了适用于 Visual Studio CodeQt for Python 扩展,并完成了相应配置,所以可以直接在 Visual Studio Code 中通过鼠标右键菜单操作完成将窗体文件.ui)转换为窗体 Python 程序文件.py)。

有两种转换方法:

(1) 方法1:在当前窗体文件MyMainWindow.ui)代码编辑器窗口中,通过鼠标右键菜单【Compile Form (Qt Designer UI File) into Qt for Python File】,来完成编译转换。

(2) 方法2:在【资源管理器】下,选择当前窗体文件MyMainWindow.ui),通过鼠标右键菜单【Compile Form (Qt Designer UI File) into Qt for Python File】,来完成编译转换。


顺利的话,可以在【资源管理器】的当前窗体文件MyMainWindow.ui)同级目录下看到多出了一个新创建的 Python 文件(文件名为:MyMainWindow.py)。

同样,为了便于区分正常 Python 文件与窗体 Python 文件,通常会在转换成的窗体 Python 文件名前加个前缀(ui_),这样文件名就变为了:ui_MyMainWindow.py,比较一目了然。


需要特别提醒的一点是:借助 Qt Designer 工具可视化设计窗体,只要窗体有所变动,那么就必须重新将窗体文件编译转换成对应的窗体 Python 程序文件(必要时还需要进行相应代码完善)。


4.3 窗体Python程序文件参考

编译转换后的窗体 Python 程序文件ui_MyMainWindow.py)内容参考如下:

 # -*- coding: utf-8 -*-
 
 ################################################################################
 ## Form generated from reading UI file 'MyMainWindow.ui'
 ##
 ## Created by: Qt User Interface Compiler version 6.0.0
 ##
 ## WARNING! All changes made in this file will be lost when recompiling UI file!
 ################################################################################
 
 from PySide6.QtCore import *
 from PySide6.QtGui import *
 from PySide6.QtWidgets import *
 
 
 class Ui_MainWindow(object):
     def setupUi(self, MainWindow):
         if not MainWindow.objectName():
             MainWindow.setObjectName(u"MainWindow")
         MainWindow.resize(416, 158)
         self.centralwidget = QWidget(MainWindow)
         self.centralwidget.setObjectName(u"centralwidget")
         self.gridLayout = QGridLayout(self.centralwidget)
         self.gridLayout.setObjectName(u"gridLayout")
         self.lineEdit = QLineEdit(self.centralwidget)
         self.lineEdit.setObjectName(u"lineEdit")
         sizePolicy = QSizePolicy(QSizePolicy.Expanding, QSizePolicy.Fixed)
         sizePolicy.setHorizontalStretch(0)
         sizePolicy.setVerticalStretch(0)
         sizePolicy.setHeightForWidth(self.lineEdit.sizePolicy().hasHeightForWidth())
         self.lineEdit.setSizePolicy(sizePolicy)
         font = QFont()
         font.setBold(True)
         font.setItalic(False)
         self.lineEdit.setFont(font)
         self.lineEdit.setLayoutDirection(Qt.LeftToRight)
         self.lineEdit.setAutoFillBackground(False)
         self.lineEdit.setStyleSheet(u"color: blue;\n"
 "font: bold; \n"
 "font-size: 13px;")
         self.lineEdit.setAlignment(Qt.AlignCenter)
 
         self.gridLayout.addWidget(self.lineEdit, 0, 0, 1, 4)
 
         self.btnChange = QPushButton(self.centralwidget)
         self.btnChange.setObjectName(u"btnChange")
 
         self.gridLayout.addWidget(self.btnChange, 1, 0, 1, 1)
 
         self.btnReset = QPushButton(self.centralwidget)
         self.btnReset.setObjectName(u"btnReset")
 
         self.gridLayout.addWidget(self.btnReset, 1, 1, 1, 1)
 
         self.btnClear = QPushButton(self.centralwidget)
         self.btnClear.setObjectName(u"btnClear")
 
         self.gridLayout.addWidget(self.btnClear, 1, 2, 1, 1)
 
         self.btnQuit = QPushButton(self.centralwidget)
         self.btnQuit.setObjectName(u"btnQuit")
 
         self.gridLayout.addWidget(self.btnQuit, 1, 3, 1, 1)
 
         MainWindow.setCentralWidget(self.centralwidget)
 
         self.retranslateUi(MainWindow)
         self.btnClear.clicked.connect(self.lineEdit.clear)
         self.btnQuit.clicked.connect(MainWindow.close)
 
         QMetaObject.connectSlotsByName(MainWindow)
     # setupUi
 
     def retranslateUi(self, MainWindow):
         MainWindow.setWindowTitle(QCoreApplication.translate("MainWindow", u"PySide6 \u793a\u4f8b\u7a0b\u5e8f", None))
         self.lineEdit.setText(QCoreApplication.translate("MainWindow", u"\u501f\u52a9 Qt Designer \u5b8c\u6210\u7684 PySide6 GUI \u5e94\u7528\u7a0b\u5e8f\uff01", None))
         self.btnChange.setText(QCoreApplication.translate("MainWindow", u"\u6539\u8272", None))
         self.btnReset.setText(QCoreApplication.translate("MainWindow", u"\u6062\u590d", None))
         self.btnClear.setText(QCoreApplication.translate("MainWindow", u"\u6e05\u9664", None))
         self.btnQuit.setText(QCoreApplication.translate("MainWindow", u"\u5173\u95ed", None))
     # retranslateUi

窗体 Python 程序文件中实际上定义了一个 Ui_MainWindow 类。

重点代码解析如下:

——第16行代码:定义声明一个 Ui_MainWindow 类,该类继承自 QObject


——第17行代码:定义了一个 setupUi(self, MianWindow) 函数,有两个参数,第一个参数(self) 表示函数自己,第二个参数(MainWindow)是一个传入的参数,是 Qt Designer 中主窗体的 objectName 对应的属性值。

setupUi() 函数用于窗体的初始化,创建了窗体上的所有部件并设置其属性。

注: Ui_MainWindow 类并不创建窗体(MainWindow),窗体(MainWindow)是由外部传入的,作为所有界面部件的父容器。


——第67行代码:调用了 retranslateUi() 函数,该函数会在第74-81行代码进行定义。


——第71行代码:QMetaObject.connectSlotsByName(MainWindow) 语句将窗体(MainWindow)上各部件的信号与槽函数进行自动连接。


——第74-81行代码:定义了 retranslateUi() 函数,该函数设置了主窗体(MainWindow)的标题、行编辑器(lineEdit)的文字、4个按钮(btnChangebtnResetbtnClearbtnQuit)的标题。实际上,retranslateUi() 函数集中设置了窗体上所有的字符串,有利于实现软件的多语言界面。



5. 完善窗体Python程序文件

在设计窗体环节我们还有一些自定义槽函数未定义,部分部件的信号/槽尚未进行连接。所以有必要对由窗体文件转换成的窗体 Python 程序文件(如:ui_MyMainWindow.py)加以完善,主要是自定义槽函数,建立部件的信号/槽的连接。

一、在上面文件中的第70行处添加如下2行代码:

         self.btnChange.clicked.connect(self.btnChange_Clicked)
         self.btnReset.clicked.connect(self.btnReset_Clicked)

二、在上面文件中的第73行处添加如下几行代码(两个自定义槽函数):

     @Slot()
     def btnChange_Clicked(self):
         self.lineEdit.setStyleSheet("color: red; font: bold; font-size: 13px;")
 
     @Slot()
     def btnReset_Clicked(self):
         self.lineEdit.setText("借助 Qt Designer 完成的 PySide6 GUI 应用程序!")
         self.lineEdit.setStyleSheet("color: blue; font: bold; font-size: 13px;")

三、保存文件。



6. 使用转换后的窗体的Python类构建GUI应用程序

窗体 Python 程序文件中只是定义了一个 Ui_MainWindow 类,所以该窗体 Python 程序文件并不能直接运行,而是需要被其他 Python 文件调用该窗体 Python 程序文件里定义的 Ui_MainWindow 类。

6.1 编辑主程序文件代码

Visual Studio Code 中编辑 Python 主程序代码(代码参考如下),并保存为 Python 文件(如:MyPySide6App03.py)。

 from PySide6.QtWidgets import (QApplication, QMainWindow)
 from ui_MyMainWindow import Ui_MainWindow
 
 class MainWindow(QMainWindow):
     def __init__(self):
         super(MainWindow, self).__init__()
         self.ui = Ui_MainWindow()
         self.ui.setupUi(self)
 
 if __name__ == "__main__":
     import sys
 
     app = QApplication(sys.argv)
 
     window = MainWindow()
     window.show()
 
     sys.exit(app.exec_())

重点代码解析(其他代码请参见本系列第四篇文章相应部分):

——第2行代码:表示导入 ui_MyMainWindow 模块中的 Ui_MainWindow 类。

——第7行代码:使用 Ui_MainWindow 类创建一个对象(ui)。

——第8行代码:调用该对象的 setupUi() 方法,创建窗体上的部件。


6.2 运行程序

Visual Studio Code 中运行 Python 文件(MyPySide6App03.py),查看示例程序的运行效果(如下图示):

注:在 Visual Studio Code 中可以通过以下几种方式来运行 Python 程序文件:

(1) 直接点击当前 Python 文件代码编辑器右上角的【运行】图标按钮,运行 Python 程序。

(2) 在当前 Python 文件代码编辑器窗口中,通过鼠标右键菜单【在终端中运行 Python 文件】,来运行 Python 程序。

(3) 在【资源管理器】下,选择当前Python 文件,通过鼠标右键菜单【在终端中运行 Python 文件】,来运行 Python 程序。


依次点击窗口上4个按钮,测试效果如下:

  • 点击【改色】按钮,文本显示为红色。
  • 点击【恢复】按钮,恢复初始文字内容及其样式。
  • 点击【清除】按钮,文本内容被清空。
  • 点击【关闭】按钮,关闭窗口退出程序。


结束语

本系列介绍如何在 Python 中使用 Qt for Python 进行 GUI 应用程序开发。

本文是《Qt for Python 学习笔记》系列第六篇,介绍了如何借助 Qt Designer 工具进行可视化界面设计并完成一个 PySide6 GUI 应用程序开发的全过程(含重点代码解析),让读者有更进一步的体会。

接下来会对 Qt for Python布局管理进行较为详细的介绍,敬请期待!

希望本文能对您有所帮助!若文中存在疏忽不足或错误,还请不吝赐教!

相关推荐

python gui编程框架推荐以及介绍(python gui开发)

Python的GUI编程框架有很多,这里为您推荐几个常用且功能强大的框架:Tkinter:Tkinter是Python的标准GUI库,它是Python内置的模块,无需额外安装。它使用简单,功能较为基础...

python自动化框架学习-pyautogui(python接口自动化框架)

一、适用平台:PC(windows和mac均可用)二、下载安装:推荐使用命令行下载(因为会自动安装依赖库):pipinstallPyAutoGUI1该框架的依赖库还是蛮多的,第一次用的同学耐心等...

Python 失宠!Hugging Face 用 Rust 新写了一个 ML框架,现已低调开源

大数据文摘受权转载自AI前线整理|褚杏娟近期,HuggingFace低调开源了一个重磅ML框架:Candle。Candle一改机器学习惯用Python的做法,而是Rust编写,重...

Flask轻量级框架 web开发原来可以这么可爱呀~(建议收藏)

Flask轻量级框架web开发原来可以这么可爱呀大家好呀~今天让我们一起来学习一个超级可爱又实用的PythonWeb框架——Flask!作为一个轻量级的Web框架,Flask就像是一个小巧精致的工...

Python3使用diagrams生成架构图(python架构设计)

目录技术背景diagrams的安装基础逻辑关系图组件簇的定义总结概要参考链接技术背景对于一个架构师或者任何一个软件工程师而言,绘制架构图都是一个比较值得学习的技能。这就像我们学习的时候整理的一些Xmi...

几个高性能Python网络框架,高效实现网络应用

Python作为一种广泛使用的编程语言,其简洁易读的语法和强大的生态系统,使得它在Web开发领域占据重要位置。高性能的网络框架是构建高效网络应用的关键因素之一。本文将介绍几个高性能的Python网络框...

Web开发人员的十佳Python框架(python最好的web框架)

Python是一种面向对象、解释型计算机程序设计语言。除了语言本身的设计目的之外,Python的标准库也是值得大家称赞的,同时Python还自带服务器。其它方面,Python拥有足够多的免费数据函数库...

Diagram as Code:用python代码生成架构图

工作中常需要画系统架构图,通常的方法是通过visio、processon、draw.io之类的软件,但是今天介绍的这个软件Diagrams,可以通过写Python代码完成架构图绘制,确实很co...

分享一个2022年火遍全网的Python框架

作者:俊欣来源:关于数据分析与可视化最近Python圈子当中出来一个非常火爆的框架PyScript,该框架可以在浏览器中运行Python程序,只需要在HTML程序中添加一些Python代码即可实现。该...

10个用于Web开发的最好 Python 框架

Python是一门动态、面向对象语言。其最初就是作为一门面向对象语言设计的,并且在后期又加入了一些更高级的特性。除了语言本身的设计目的之外,Python标准库也是值得大家称赞的,Python甚至还...

使用 Python 将 Google 表格变成您自己的数据库

图片来自Shutterstock,获得FrankAndrade的许可您知道Google表格可以用作轻量级数据库吗?GoogleSheets是一个基于云的电子表格应用程序,可以像大多数数据库管...

牛掰!用Python处理Excel的14个常用操作总结!

自从学了Python后就逼迫用Python来处理Excel,所有操作用Python实现。目的是巩固Python,与增强数据处理能力。这也是我写这篇文章的初衷。废话不说了,直接进入正题。数据是网上找到的...

将python打包成exe的方式(将python文件打包成exe可运行文件)

客户端应用程序往往需要运行Python脚本,这对于那些不熟悉Python语言的用户来说可能会带来一定的困扰。幸运的是,Python拥有一些第三方模块,可以将这些脚本转换成可执行的.exe...

对比Excel学Python第1练:既有Excel,何用Python?

背景之前发的文章开头都是“Python数据分析……”,使得很多伙伴以为我是专门分享Python的,但我的本意并非如此,我的重点还是会放到“数据分析”上,毕竟,Python只是一种工具而已。现在网上可以...

高效办公:Python处理excel文件,摆脱无效办公

一、Python处理excel文件1.两个头文件importxlrdimportxlwt其中xlrd模块实现对excel文件内容读取,xlwt模块实现对excel文件的写入。2.读取exce...

取消回复欢迎 发表评论: