使用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

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版