使用wxPython开发订单管理系统-核对页面

2023-10-21 15:20

本文主要是介绍使用wxPython开发订单管理系统-核对页面,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

统计页面可以自动核对客户对账信息
wx.FileDialog 文件对话框

import wx
import time
from xlrd import xldate_as_tuple
from datetime import datetime
import os
import order
from sqloperation import get_excel_row,get_excel_value,create_db,insert_db,update_db,select_from_db
#print(os.getcwd())class MyCal(wx.Frame):def __init__(self,user,parent,id):self.user=userwx.Frame.__init__ (self,parent,id,title="输入文件界面_"+self.user,pos=(200,200),size=(500,500),name='frame') #如果是顶级窗口,这个值是None,id=-1自动生成 ,name框架内的文字self.panel=wx.Panel(self)icon = wx.Icon('smart.ico')self.SetIcon(icon) self.bt_confirm=wx.Button(self.panel,label="确定对账")  #创建按钮self.bt_confirm.Bind(wx.EVT_BUTTON,self.OnclickSubmit)self.bt_back=wx.Button(self.panel,label="返回订单输入页面")self.bt_back.Bind(wx.EVT_BUTTON,self.OnclickRegister)self.title=wx.StaticText( self.panel,label="选择统计文件")#,style=0  #相当于tkinter中的Labelself.label_my=wx.StaticText( self.panel,label="自己的文件:")self.text_my=wx.TextCtrl( self.panel,style=wx.TE_LEFT)  #相当于tkinter的Entryself.bt_choose_1=wx.Button(self.panel,label="选择自己文件")self.bt_choose_1.Bind(wx.EVT_BUTTON,self.Onchoose_1)self.label_customer=wx.StaticText(self.panel,label="客户的文件:")self.text_customer=wx.TextCtrl( self.panel,style=wx.TE_LEFT)self.bt_choose_2=wx.Button(self.panel,label="选择客户文件")self.bt_choose_2.Bind(wx.EVT_BUTTON,self.Onchoose_2)#控件横向排列hsizer_user=wx.BoxSizer(wx.HORIZONTAL)hsizer_user.Add(self.label_my,proportion=0,flag=wx.ALL,border=5)  #hsizer_user横向第一行hsizer_user.Add(self.text_my,proportion=1,flag=wx.ALL,border=5)  #proportion=0表示不变,proportion=1两倍宽度hsizer_user.Add(self.bt_choose_1,proportion=0,flag=wx.ALL,border=5) hsizer_pwd=wx.BoxSizer(wx.HORIZONTAL)    #横向第二行hsizer_pwd.Add(self.label_customer,proportion=0,flag=wx.ALL,border=5)hsizer_pwd.Add(self.text_customer,proportion=1,flag=wx.ALL,border=5)hsizer_pwd.Add(self.bt_choose_2,proportion=0,flag=wx.ALL,border=5)                                     #控件纵向排列vsizer_all=wx.BoxSizer(wx.VERTICAL)vsizer_all.Add(self.title,proportion=0,flag=wx.BOTTOM|wx.TOP|wx.ALIGN_CENTER,border=45)vsizer_all.Add(hsizer_user,proportion=0,flag=wx.EXPAND|wx.LEFT|wx.RIGHT,border=15)vsizer_all.Add(hsizer_pwd,proportion=0,flag=wx.EXPAND|wx.LEFT|wx.RIGHT,border=15)vsizer_all.Add(self.bt_confirm,proportion=0,flag=wx.EXPAND|wx.LEFT|wx.RIGHT,border=15)vsizer_all.AddSpacer(100)vsizer_all.Add(self.bt_back,proportion=0,flag=wx.ALIGN_LEFT|wx.LEFT|wx.RIGHT|wx.TOP,border=15)self.panel.SetSizer(vsizer_all)font=wx.Font(16,wx.DEFAULT,wx.FONTSTYLE_NORMAL,wx.NORMAL,underline=False)self.title.SetFont(font)def OnclickSubmit(self,event):my_file= self.text_my.GetValue()  # self.paths_my[0]    #file_name=self.text_customer.GetValue()  #self.paths_customer[0]  #print("file_name",file_name)if file_name:file_name_short=file_name.split()[0].split("\\")[-1]print(my_file,file_name)info_fields="ID INTEGER PRIMARY KEY AUTOINCREMENT, 日期 DATE,客户 TEXT,调度单号 TEXT, 线路 TEXT, 车型 TEXT ,书号 TEXT, 车辆信息 TEXT,\驾驶员 TEXT,调度 TEXT,税前运费 REAL default 0, 含税运费 REAL default 0,税前其它 REAL default 0,含税其它费用 REAL default 0, \运费客户计 REAL default 0 ,运费来源文件 TEXT ,其它费用客户计 REAL default 0,\其它费用来源文件 TEXT, 费用差异 REAL ,是否结案 TEXT default False,关联 REAL default 0 ,\进仓费 REAL default 0,停车费 REAL default 0,换托盘 REAL default 0,买标签 REAL default 0 ,送货费 REAL default 0 ,\压车费 REAL default 0 ,垫付费用  REAL default 0,给司机费用  REAL default 0"create_db("费用明细",info_fields)if my_file:#s=time.time()rows=get_excel_row(my_file,0)for i in range(2,rows):value=get_excel_value(i,1, 12,my_file)charge=["{0:.1f}".format(value[-3]),"{0:.1f}".format(value[-2]),"{0:.1f}".format(value[-1])]date=value[0]keyindate=str(datetime(*xldate_as_tuple(date,0)).strftime("%Y-%m-%d"))newvalue=str(tuple(([keyindate]+value[1:8]+charge)))fields="日期,调度单号, 线路 , 车型  ,书号 , 车辆信息 ,驾驶员 ,调度,税前运费, 含税运费 ,含税其它费用 "insert_db("费用明细",fields,newvalue)#e=time.time()#print("cost_time_no_thread",e-s)if  file_name:rows_customer=get_excel_row(file_name,0)count=0count_other=0    for i in range(3,rows_customer):value=get_excel_value(i,1, 15,file_name)MO=value[13]freight=value[8]other=value[9]#print("MO",MO)#mtime = os.stat(file_name).st_mtime#file_modify_time = time.strftime('%Y-%m-%d ', time.localtime(mtime))#print(file_modify_time)#.strftime("%Y-%m-%d"))result=select_from_db("调度单号","费用明细","调度单号",MO)print("result",result)if result:if freight:  #如果'运费'项有数据#values=str(tuple([freight,file_name]))update_db("费用明细","运费客户计",freight,"调度单号",MO)update_db("费用明细","运费来源文件",file_name_short,"调度单号",MO)check_result=select_from_db("(含税运费+含税其它费用 )- (运费客户计+其它费用客户计)","费用明细","调度单号",MO)[0]update_db("费用明细","费用差异",check_result,"调度单号",MO)  #更新费用差异count+=1if other:  #如果'其它费用'项有数据#values=str(tuple([other,file_name]))update_db("费用明细","其它费用客户计",other,"调度单号",MO)update_db("费用明细","其它费用来源文件",file_name_short,"调度单号",MO)check_result=select_from_db("(含税运费+含税其它费用)- (运费客户计+其它费用客户计)","费用明细","调度单号",MO)[0]update_db("费用明细","费用差异",check_result,"调度单号",MO)count_other+=1wx.MessageBox("已输入完毕")            def OnclickRegister(self,event):self.panel.Parent.Hide()frame=order.MyFrame("usertest",parent=None,id=-1)frame.Show()def Onchoose_1(self,event):wildcard = "excel source (*.xls)|*.xlsx|"     \"All files (*.*)|*.*"dlg = wx.FileDialog(self, message="Choose a file选择文件",defaultDir=os.path.join(os.getcwd(),"我的备份"),defaultFile="",wildcard=wildcard,style=wx.FD_OPEN | wx.FD_MULTIPLE |wx.FD_FILE_MUST_EXIST |wx.FD_PREVIEW)if dlg.ShowModal() == wx.ID_OK:self.paths_my = dlg.GetPaths()print("self.paths_my ",self.paths_my )self.text_my.SetValue(self.paths_my [0])#print("os.getcwd()",os.getcwd())def Onchoose_2(self,event):wildcard = "excel source (*.xls)|*.xlsx|"     \"All files (*.*)|*.*"dlg = wx.FileDialog(self, message="Choose a file选择文件",defaultDir=os.path.join(os.getcwd(),"我的备份"),defaultFile="",wildcard=wildcard,style=wx.FD_OPEN | wx.FD_MULTIPLE |wx.FD_FILE_MUST_EXIST |      #wx.FD_CHANGE_DIR | wx.FD_PREVIEW)if dlg.ShowModal() == wx.ID_OK:   #确认则选择self.paths_customer = dlg.GetPaths()  #返回值是列表print("self.paths_customer ",self.paths_customer )self.text_customer.SetValue(self.paths_customer [0])#print("os.getcwd()",os.getcwd())if __name__=="__main__":app=wx.App()      frame=MyCal("usertst",parent=None,id=-1)frame.Show()app.MainLoop()  

在这里插入图片描述

这篇关于使用wxPython开发订单管理系统-核对页面的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/255232

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca