【发布时间】:2018-07-30 16:02:03
【问题描述】:
import pandas as pd
import csv
from tkinter import *
master = Tk()
textBox = Text(master, height=1, width=10)
textBox.grid(row=0, column=1)
fileVar = StringVar()
fileLabel = Label(master, textvariable=fileVar)
fileLabel.grid(row=3, column=1)
fileVar2 = StringVar()
fileLabel2 = Label(master, textvariable=fileVar)
fileLabel2.grid(row=3, column=2)
def retrieve_input():
Customer = textBox.get("1.0","end-1c")
fileread = pd.read_csv('50.csv', encoding='latin-1')
filevalue = fileread.loc[fileread['Customer'].str.contains(Customer, na=False),"Jul-18\nQty"]
productheader = fileread.loc[fileread['Customer'].str.contains(Customer, na=False), 'Product']
fileVar.set(productheader)
fileVar2.set(filevalue)
button1 = Button(master,text="Show Values", command=lambda: retrieve_input())
button1.grid(row=4, column=1)
mainloop()
我有这个程序可以在 Tkinter Gui 中打印特定行中的特定值。但是打印的值的格式非常混乱,我不确定如何清理它,此外我希望它不显示旁边标记的数字,只是产品名称(蓝色模糊)和与之关联的值(这是带小数的数值)。
这是图形用户界面的快照:
此外,在列表的最底部,还会显示:
理想情况下,我希望它只显示标题(7 月 18 日)而不是数据类型
如果有帮助的话,这些是预测文件,(带有日期的标题的原因)
这是我的 csv 文件的虚拟图像:
【问题讨论】:
-
您的示例使用
master,但您从未声明master是什么。我假设这是Tk()实例?还将command=lambda: retrieve_input()更改为command=retrieve_input。你不需要 lambda。 -
@Mike-SMT 是的!我刚刚添加了它。而且,这个代码是一个更大的代码的一部分,我必须压缩它才能显示在这里。实际上,我有几个用户输入,而 lamda 函数是原始代码运行的唯一方式
-
这很好,但就您的示例代码而言,不需要它。我们可以从您的 CSV 中获取示例行吗?这样我们就可以实际测试代码了。
-
它不一定是您的真实数据。只是我们可以使用的相同格式的东西。此外,您的蓝色涂鸦并没有真正隐藏数据。我可以缩放和阅读。最好只删除列中的值,然后做一个屏幕截图,然后撤消删除。
-
哼。当我尝试将
filevalue转换为列表时,我只得到 Jul-18 列中的数字,没有别的。在文本框中使用这个可能会很棘手。您可能需要读取每行中每个单元格的数据并使用列表来跟踪它们,然后将这些数据均匀地放入文本框或一些标签中。
标签: python pandas csv tkinter format