【问题标题】:Python: get text from tkinter scrolledtext and read line by linePython:从 tkinter scrolledtext 获取文本并逐行读取
【发布时间】:2021-01-16 16:44:47
【问题描述】:

我目前正在开发一个简单的 txt 转换器。数据从 txt 文件加载到滚动文本小部件中。现在我想逐行阅读这个文本(因为我想有机会编辑原始数据)并根据滚动文本数据进行转换。但是,我无法得到令人满意的结果。

如果我只是打印使用.get('1.0', 'end-1c') 获得的文本,它看起来与滚动文本数据完全一样。现在我想用for 循环逐行阅读它,并用stripsplit 命令将它分开。基本上和我直接从文件中读取时一样,但它不起作用。

输入数据包含大量空格:

"                  1267    33311225.807"
"                  1268    33311224.395"

我希望 ['1267', '33311225.807']。相反,我为每个数字换行:

[1]
[2]
[6]
[8]
...

等等。

import tkinter.scrolledtext as tkst
from tkinter import filedialog
from tkinter import ttk

root = tk.Tk()
root.title("Converter")
root.geometry('1000x690+200+50')
tab_parent = ttk.Notebook(root)

tab1 = ttk.Frame(tab_parent)
tab_parent.add(tab1, text="  convert  ")

frame1 = tk.Frame(tab1)
textPad_top = tkst.ScrolledText(master=frame1)

coordinates_text = textPad_top.get('1.0', 'end-1c')
for line in coordinates_text:
    line_splitted = line.strip().split(" ")
    read_coordinates = [ele for ele in line_splitted if ele.strip()]
    point_id.append(read_coordinates[0])
    r_value.append(read_coordinates[1])

root.mainloop()

最终我想要几个列表。源文件中给定的每一列一个。 我是编程的绝对初学者,非常感谢您的帮助。

【问题讨论】:

    标签: python tkinter tkinter-scrolledtext


    【解决方案1】:

    当您遍历一个字符串时,它将遍历您所报告的每个字符。

    如果要遍历每一行,则需要在换行符上拆分数据

    for line in coordinates_text.split("\n"):
        ...
    

    【讨论】:

    • 很高兴知道 - 效果很好。非常感谢!但是,如果我打开一个文件并对其进行迭代,我有什么数据类型?我以为它也是一个字符串。
    • @Michael:如果您遍历文件,则数据类型是打开的文件。打开的文件设计为在您对其进行迭代时一次返回一行。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-11-12
    • 2014-12-21
    • 2014-06-13
    • 1970-01-01
    相关资源
    最近更新 更多