import wx
import wx.xrc
import pandas as pd

from conf.env import *

# 允许选择的文件
wildcard = "Python source (*.xls; *.xlsx)|*.xls;*.xlsx" class WxForms(wx.Frame):
def __init__(self):
wx.Frame.__init__(self, None, id=wx.ID_ANY,
title="File conversion",
pos=wx.DefaultPosition,
size=(520, 200))
# 框架布局
panel = wx.Panel(self, wx.ID_ANY)
# 输入文本域
LabelCfn = wx.StaticText(panel, id=wx.ID_ANY, label='文件设置:', pos=(15, 5), size=(80, 25))
self.Txt_Input = wx.TextCtrl(panel, id=wx.ID_ANY, pos=(95, 5), size=(300, 25))
# 事件按钮
btnO = wx.Button(panel, label="...", pos=(405, 5), size=(70, 25))
# 生成文本路径
labelCfn2 = wx.StaticText(panel, id=wx.ID_ANY, label='输出文件夹:', pos=(15, 45), size=(80, 25))
self.Txt_Output = wx.TextCtrl(panel, id=wx.ID_ANY, pos=(95, 45), size=(300, 25))
# 事件按钮
btnS = wx.Button(panel, label="...", pos=(405, 45), size=(70, 25))
# 事件执行按钮
btnC = wx.Button(panel, label='执行', pos=(395, 85), size=(80, 35))
# 事件绑定
btnO.Bind(wx.EVT_BUTTON, self.onChioceFile)
   btnS.Bind(wx.EVT_BUTTON, self.OnChioceDir)
btnC.Bind(wx.EVT_BUTTON, self.OnExecute)
  
  def onChioceFile(self, event): """ 按钮事件选择一个Excel文件 """ dlg = wx.FileDialog( self, message="Choose a file", defaultFile="", wildcard=wildcard, style=wx.FLP_OPEN | wx.FD_MULTIPLE | wx.DD_CHANGE_DIR ) if dlg.ShowModal() == wx.ID_OK: tmp = "" paths = dlg.GetPaths() # print(paths) for path in paths: tmp = tmp + path self.Txt_Input.SetValue(tmp) dlg.Destroy()
def onChioceFile(self, event):
"""
按钮事件选择一个Excel文件
"""
dlg = wx.FileDialog(
self, message="Choose a file",
defaultFile="",
wildcard=wildcard,
style=wx.FLP_OPEN | wx.FD_MULTIPLE | wx.DD_CHANGE_DIR
)
if dlg.ShowModal() == wx.ID_OK:
tmp = ""
paths = dlg.GetPaths()
# print(paths)
for path in paths:
tmp = tmp + path
self.Txt_Input.SetValue(tmp)
dlg.Destroy()
def OnChioceDir(self, event):
"""
按钮事件选择文件夹
:param event:
:return:
"""
dlg = wx.DirDialog(self, u"选择文件夹", style=wx.DD_DEFAULT_STYLE)
if dlg.ShowModal() == wx.ID_OK:
path = dlg.GetPath() # 文件夹路径
self.Txt_Output.SetValue(path)
dlg.Destroy()
def OnExecute(self, event):
"""
获取Excel文件并转换格式
:param event:
:return:
"""
out_path = self.Txt_Output.GetValue()
in_file = self.Txt_Input.GetValue()
sheets = pd.read_excel(in_file)
dir_name, file_name = os.path.split(in_file)
shot_name,extension = os.path.splitext(file_name) if out_path:
currentPath = os.path.join(out_path, shot_name + '.csv')
else:
currentPath = os.path.join(BASE_DIR,'resources\OutPuts', shot_name + '.csv')
dt = pd.DataFrame(sheets)
dt.to_csv(currentPath)
self.Destroy()
app = wx.App(False)
frame = WxForms()
frame.Show(True)
app.MainLoop()
 

												

wxpython的简单的应用的更多相关文章

  1. wxPython的简单应用

  2. wxPython 的简单框架实例

    #coding:utf-8 import wx def load(event): file = open(filename.GetValue(),'r') contents.SetValue(file ...

  3. 使用源码编译wxpython-基于python2.7

    1.前言 本文主要讲述在linux环境下进行编译wxpython,在windows下面安装wxpython很简单,只要下载,然后直接执行exe文件,下一步下一步即可安装,在linux下面,则具有很多步 ...

  4. 浅谈 Python 程序和 C 程序的整合

    源地址:http://www.ibm.com/developerworks/cn/linux/l-cn-pythonandc/ 概览 Python 是一种用于快速开发软件的编程语言,它的语法比较简单, ...

  5. 谈 Python 程序和 C 程序的整合 (转载)

    http://www.ibm.com/developerworks/cn/linux/l-cn-pythonandc/ 概览 Python 是一种用于快速开发软件的编程语言,它的语法比较简单,易于掌握 ...

  6. wxPython中按钮、文本控件的简单运用

    本节学习图形用户界面 ------------------------ 本节介绍如何创建python程序的图形用户界面(GUI),也就是那些带有按钮和文本框的窗口.这里介绍wxPython : 下载地 ...

  7. python使用wxPython创建一个简单的文本编辑器。

    ubuntu下通过'sudo apt-get install python-wxtools'下载wxPython.load和save函数用于加载和保存文件内容,button通过Bind函数绑定这两个函 ...

  8. wxPython中文教程 简单入门加实例

    wx.Window 是一个基类,许多构件从它继承.包括 wx.Frame 构件.技术上这意味着,我们可以在所有的 子类中使用 wx.Window 的方法.我们这里介绍它的几种方法: * SetTitl ...

  9. wxPython简单入门

    wxPython简介 wxPython 是 Python 语言的一套优秀的 GUI 图形库,允许 Python 程序员很方便的创建完整的.功能键全的  GUI 用户界面. wxPython 是作为优秀 ...

随机推荐

  1. 防止 IOS 和 安卓 自动锁屏

    Ios代码 在文件AppController中的 didFinishLaunchingWithOptions函数中加一行代码即可: [[UIApplication sharedApplication] ...

  2. Python3.x:获取代理ip以及使用

    Python3.x:获取代理ip以及使用 python爬虫浏览器伪装 #导入urllib.request模块 import urllib.request #设置请求头 headers=("U ...

  3. Python3.x:SQLAlchemy操作数据库

    Python3.x:SQLAlchemy操作数据库 前言 SQLAlchemy是一个ORM框架(Object Rational Mapping,对象关系映射),它可以帮助我们更加优雅.更加高效的实现数 ...

  4. logstash运输器以及kibana的更多操作

    为了达到不会因为ELK中的某一项组件因为故障而导致整个ELK工作出问题,于是 将logstash收集到的数据存入到消息队列中如redis,rabbitMQ,activeMQ或者kafka,这里以red ...

  5. 20145303刘俊谦 《Java程序设计》第三周学习总结

    20145303刘俊谦 <Java程序设计>第三周学习总结 教材学习内容总结 1.类与对象: 类:对现实生活中事物的描述,定义类时用关键词class 对象:这类事物实实在在存在的个体,利用 ...

  6. RocEDU.阅读.写作《苏菲的世界》书摘(五)

    在谈到如何获取确实的知识时,当时许多人持一种全然怀疑的论调,认为人应该接受自己一无所知事实.但笛卡尔却不愿如此.他如果接受这个事实,那他就不是一个真正的哲学家了.他的态度就像当年苏格拉底不肯接受诡辩学 ...

  7. 2045331 《Java程序设计》第09周学习总结

    2045331 <Java程序设计>第09周学习总结 教材学习内容总结 第十六章 整合数据库 16.1.1JDBC简介 1.JDBC是用于执行SQL的解决方案,开发人员使用JDBC的标准接 ...

  8. 一文弄懂神经网络中的反向传播法——BackPropagation【转】

    本文转载自:https://www.cnblogs.com/charlotte77/p/5629865.html 一文弄懂神经网络中的反向传播法——BackPropagation   最近在看深度学习 ...

  9. git基础常用维护命令

    开发模式介绍 master为生产环境分支 trunk为测试环境分支 开发分支由程序员自己取名 比如来一个新项目之后,下面步骤都是在本地操作 1.从本地获取远程master最新代码,保证本地master ...

  10. django的基本用法

    1.项目创建 # 新建一个文件夹DjangoProjects# 切换到需要的文件夹创建虚拟环境 C:\Projects\DjangoProjects>python -m venv test_ve ...