前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >macOS 使用 Qt Designer + pyUIC 完成一个小工具

macOS 使用 Qt Designer + pyUIC 完成一个小工具

作者头像
桑鱼
发布2020-05-08 17:14:55
5.6K0
发布2020-05-08 17:14:55
举报
最终效果

选择城市后点击运行可以查看接口响应信息,用到的接口是 :http://notify.mse.sogou.com/weather?city=北京

1 环境准备

安装 PyQt5

代码语言:javascript
复制
pip3 install PyQt5

安装 PyQt5-tools

代码语言:javascript
复制
pip3 install pyqt5-tools

安装 Qt Designer

下载地址

安装 pyuic5-tool

代码语言:javascript
复制
pip3 install pyuic5-tool
2 配置 Qt Designer

name :可以随便填 program :填写 Qt Designer 的安装路径 working directory:填写 ProjectFileDir

上面的步骤完成后就可以工具栏Tools-External Tools 里面就可以看到Qt Designer这个扩展功能了,可以快速启动Designer

3 配置 pyUIC

pyUIC 可以将 .ui 转为 .py 格式的文件,保存在当前 python 项目同目录中

name :可以随便填 program :填写 pyUIC 路径 Arguments:FileName -o FileNameWithoutExtension.py working directory:FileDir

同样,Tools-External Tools 里面就可以看到 pyUIC 这个扩展功能了

4 使用 Qt Designer 绘制页面

完成页面绘制后,将页面信息保存,此时保存的是 .ui 格式的,记住保存地址

将.ui文件移动到我们创建的 Python 项目中

右击.ui文件 找到 External Tools,单击 pyUIC 生成.py 格式的文件

代码生成后,我们先准备执行接口请求的脚本,将请求封装到 WeatherTest类中

代码语言:javascript
复制
import requests


class WeatherTest:
    def __init__(self):
        self

    def testWeather(self, city):
        url = "http://notify.mse.sogou.com/weather"

        querystring = {"city": city}

        headers = {
            'User-Agent': "PostmanRuntime/7.16.3",
            'Accept': "*/*",
            'Cache-Control': "no-cache",
            'Postman-Token': "de3c837b-6f0c-48c8-a49d-1ca310c98917,d028ac2b-f12f-4fbd-ab4a-2aabfb32ab13",
            'Host': "notify.mse.sogou.com",
            'Accept-Encoding': "gzip, deflate",
            'Cookie': "IPLOC=CN1100",
            'Connection': "keep-alive",
            'cache-control': "no-cache"
        }

        response = requests.request("GET", url, headers=headers, params=querystring)
        print(response.text)

然后我们在刚刚生成的 .py 文件中,对代码进行修改增加城市列表和按钮绑定事件,这样就可以实现点击→触发→输出→展示的过程了

0.界面初始化

代码语言:javascript
复制
 def __init__(self):
      super().__init__()
      self.setupUi(self)
      # 添加下拉列表选项
      self.comboBox.addItem("北京")
      self.comboBox.addItem("上海")
      # 省略添加了其他城市
      # 重定向输出流
      sys.stdout = EmittingStr(textWritten=self.outputWritten)
      sys.stderr = EmittingStr(textWritten=self.outputWritten)
      # 绑定按钮事件
      self.pushButton.clicked.connect(self.buttClicked)

1.绑定按钮事件 - 获取参数&触发请求

代码语言:javascript
复制
def buttClicked(self):
    est = WeatherTest()
    selectedCity = self.comboBox.currentText()
    test.testWeather(city=selectedCity)

2.重定向输出流 - 展示在文本区域内

代码语言:javascript
复制
def outputWritten(self, text):
    cursor = self.textBrowser.textCursor()
    cursor.movePosition(QtGui.QTextCursor.End)
    cursor.insertText(text)
    self.textBrowser.setTextCursor(cursor)
    self.textBrowser.ensureCursorVisible()
  1. 定义 EmittingStr 类
代码语言:javascript
复制
class EmittingStr(QtCore.QObject):
    textWritten = QtCore.pyqtSignal(str)  # 定义一个发送str的信号

    def write(self, text):
        self.textWritten.emit(str(text))
  1. 主程序入口
代码语言:javascript
复制
if __name__ == '__main__':
    app = QApplication(sys.argv)
    ui = Ui_MainWindow()
    ui.show()
    sys.exit(app.exec_())

完成上面的步骤直接运行程序就可以看到界面,选择一个城市,执行就能看到接口请求的结果了~

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 最终效果
  • 1 环境准备
  • 2 配置 Qt Designer
  • 3 配置 pyUIC
  • 4 使用 Qt Designer 绘制页面
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档