今天给大家介绍下python gui界面的三级联动效果,我们用工具eric6来实现,先看下效果图。

首先我们先创建项目linkage,再新建窗体进入到Qt设计师工具开始设计界面,完成后保存并退出。

在eric6工具中编译窗体,再选择生成对话框代码,我们在复选框的函数中勾选on_province_activated(int)这个函数,确认后生成两个新的py文件,我们通常在ui_linkage.py文件中处理界面编辑优化,在linkage.py文件中处理事件机制(槽),我们三级联动效果主要在linkage.py中完成功能代码。

 # -*- coding: utf-8 -*-

 """
Module implementing Linkage.
""" from PyQt5.QtCore import pyqtSlot
from PyQt5.QtWidgets import QDialog, QApplication
import json from Ui_linkage import Ui_Linkage class Linkage(QDialog, Ui_Linkage):
"""
Class documentation goes here.
"""
def __init__(self, parent=None):
"""
Constructor @param parent reference to the parent widget
@type QWidget
"""
super(Linkage, self).__init__(parent)
self.setupUi(self)
#初始化操作委托到initUI()
self.initUI()
def initUI(self):
with open('data.json', 'r', encoding='utf-8') as f:
self.data=json.load(f)
#初始化三级联动下拉框的数据
self.choosep=''
self.choosec=''
self.choosea=''
self.label_result.setText('选择结果:(未选择)')
#清理当前下拉框的内容
self.province.clear()
self.city.clear()
self.area.clear()
#初始化下拉框的展示内容
self.province.addItem('-请选择-')
for s in self.data:
print(s['name'])
self.province.addItem(s['name']) @pyqtSlot(int)
def on_province_activated(self, index):
"""
Slot documentation goes here. @param index DESCRIPTION
@type int
"""
#因为我们在初始化的时候添加了请选择,所以需要做判断看当前是否点击它了
if index==0:
#点击请选择按钮后,我们需要对省、市、区进行三级联动数据清理
self.choosep=''
self.choosec=''
self.choosea=''
#需要清理后面市、区的内容
self.city.clear()
self.area.clear()
return
#获取当前选择的省份数据(因为index=0的时候是请选择所以需要-1)
self.choosep=self.data[index-1]
#清理市、区下拉框内容
self.city.clear()
self.area.clear()
#当前所选省得市级下拉框内容添加
self.city.addItem('-请选择-')
for s in self.choosep['city']:
self.city.addItem(s['name']) @pyqtSlot(int)
def on_city_activated(self, index):
"""
Slot documentation goes here. @param index DESCRIPTION
@type int
"""
if index==0:
#初始化市、区数据
self.choosec=''
self.choosea=''
#清理区的下拉框内容
self.area.clear()
return
#获取当前所选市的数据
self.choosec=self.choosep['city'][index-1]
#清理区的下拉框内容
self.area.clear()
#当前所选市的区下拉框内容添加
self.area.addItem('-请选择-')
for s in self.choosec['area']:
self.area.addItem(s) @pyqtSlot(int)
def on_area_activated(self, index):
"""
Slot documentation goes here. @param index DESCRIPTION
@type int
"""
if index==0:
#初始化区数据
self.choosea=''
return
#获取当前所选区数据
self.choosea=self.choosec['area'][index-1] @pyqtSlot()
def on_sure_clicked(self):
str_result='选择结果:(未选择)'
if self.choosep:
str_result=self.choosep['name']
if self.choosec:
str_result=str_result+'-'+self.choosec['name']
if self.choosea:
str_result=str_result+'-'+self.choosea
self.label_result.setText(str_result) @pyqtSlot()
def on_cancel_clicked(self):
#返回初始状态
self.initUI()
if __name__=='__main__':
import sys
app=QApplication(sys.argv)
linkage=Linkage()
linkage.show()
sys.exit(app.exec_())

PyQt5--基础篇:用eric6工具实现三级联动效果的更多相关文章

  1. js之省市区(县)三级联动效果

    省市区(县)三级联动效果,是我们软件开发比较常用的,特别是对一些crm,erp之类,当然也包括其他的后台管理系统,基本都涉及到,今天贴出这个常用的,方便个人复用和大家使用 <!DOCTYPE h ...

  2. Ajax来实现下拉框省市区三级联动效果(服务端基于express)

    //服务端JS代码: //提供服务端的处理 const express = require('express'); const fs = require('fs'); const app = expr ...

  3. 用Vue2仿京东省市区三级联动效果

    三级联动,随着越来越多的审美,出现了很多种,好多公司都仿着淘宝的三级联动 ,好看时尚,so我们公司也一样……为了贴代码方便,我把写在data里面省市区的json独立了出来,下载贴进去即可用,链接如下 ...

  4. Vue如何使用vue-area-linkage实现地址三级联动效果

    很多时候我们需要使用地址三级联动,即省市区三级联动.网上有很多插件,在此介绍Vue的一款地区联动插件:vue-area-linkage,下面介绍如何使用这个插件实现地址联动效果:         1. ...

  5. jQuery三级联动效果代码(省、市、区)

    很长时间都不用jquery了,有人问我jquery写三级联动的插件我就写好了发出来吧,正好需要的人都可以看看. 一.html代码 <!DOCTYPE html> <html> ...

  6. 图学java基础篇之集合工具

    两个工具类 java.utils下又两个集合相关_(准确来说其中一个是数组的)_的工具类:Arrays和Collections,其中提供了很多针对集合的操作,其中涵盖了一下几个方面: 拷贝.填充.反转 ...

  7. 【Android开发日记】之基础篇(二)——Android的动画效果

          什么是动画,动画的本质是通过连续不断地显示若干图像来产生“动”起来的效果.比如说一个移动的动画,就是在一定的时间段内,以恰当的速率(起码要12帧/秒以上,才会让人产生动起来的错觉)每隔若干 ...

  8. ionic+AnjularJs实现省市县三级联动效果

    建议对ionic和AnjularJs有一定了解的人可以用到,很多时候我们要用到选择省份.城市.区县的功能,现在就跟着我来实现这个功能吧,用很少的代码(我这里是根据客户的要求,只显示想要显示的部分省份和 ...

  9. 基于jQuery+JSON的省市县 二级 三级 联动效果

    省市区联动下拉效果在WEB中应用非常广泛,尤其在一些会员信息系统.电商网站最为常见.开发者一般使用Ajax实现无刷新下拉联动.本文将讲述,利用jQuery插件,通过读取JSON数据,实现无刷新动态下拉 ...

随机推荐

  1. 【原创】快应用QuickApp--HelloWorld体验

    快应用: 快应用是九大手机厂商基于硬件平台共同推出的新型应用生态.用户无需下载安装,即点即用,享受原生应用的性能体验. 3月20日在北京联合召开快应用标准启动发布会.过去1天了,官网(快应用官方网站) ...

  2. 利用sfc文件构建网络渗透

      收集哈希 SCF(Shell命令文件)文件可用于执行一组有限的操作,例如显示Windows桌面或打开Windows资源管理器,这并不是什么新鲜事.然而,一个SCF文件可以用来访问一个特定的UNC路 ...

  3. shiro授权

    一.shiro-permission.ini shiro-permission.ini里面的内容相当于在数据库 #用户 [users] #用户zhang的密码是123,此用户具有role1和role2 ...

  4. SpringMvc的传递参数方式 -- url / requestMapping

    在使用spring的项目中,前台传递参数到后台是经常遇到的事, 我们必须熟练掌握一些常用的参数传递方式和注解的使用,废话少说,直接上正文. 1. @requestMapping: 类级别和方法级别的注 ...

  5. Nginx+Tomcat 配置负载均衡集群

    一.Hello world 1.前期环境准备 准备两个解压版tomcat,如何同时启动两个tomcat,请看我的另一篇文章<一台机器同时启动多个tomcat>. nginx官网下载解压版n ...

  6. webpack学习

    // 一个常见的`webpack`配置文件 const webpack = require('webpack'); const HtmlWebpackPlugin = require('html-we ...

  7. sql操作知识点个人笔记(SQLServer篇)

    实际工作中,总会遇到一些常用的或不常用的sql,这些sql可能并没多少技术含量,但对我们本身而言,一个最大的问题就是很容易忘记.对我个人而言,以前常用的,过阵子之后再用到,发现不记得了.由此得出结论, ...

  8. SuperMap iClient 查询成功后如何传递参数?

    一.iClient API文档中的接口描述 二.范例 //定义一个this对象 this.param = new SuperMap.LonLat(point.x, point.y); querySer ...

  9. 20165226 2017-2018-3 《Java程序设计》第5学习总结

    20165226 2017-2018-3 <Java程序设计>第5周学习总结 教材学习内容总结 第七章 内部类与异常类 匿名类创建对象: new Bank() { 匿名类的类体 }: 异常 ...

  10. Item 15: 只要有可能,就使用constexpr

    本文翻译自modern effective C++,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 博客已经迁移到这里啦 如果说C++11中有什么新东西能拿"最佳困惑奖" ...