Python:从 tkinter scrolledtext 获取文本并逐行读取

问题描述

我目前正在开发一个简单的 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()

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

解决方法

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

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

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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...