Python: 从 tkinter scrolledtext 获取文本并逐行读取
Python: get text from tkinter scrolledtext and read line by line
我目前正在开发一个简单的 txt 转换器。数据从 txt 文件加载到滚动文本小部件中。现在我想逐行阅读此文本(因为我想有机会编辑原始数据)并根据滚动文本数据进行转换。但是,我得不到满意的结果。
如果我简单地打印使用 [=14=] 获得的文本,它看起来与滚动文本数据完全一样。现在我想用 for
循环逐行读取它,并用 strip
和 split
命令将它分开。基本上与我直接从文件中读取时的方式相同,但它不起作用。
输入数据包含大量空格:
" 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"):
...
我目前正在开发一个简单的 txt 转换器。数据从 txt 文件加载到滚动文本小部件中。现在我想逐行阅读此文本(因为我想有机会编辑原始数据)并根据滚动文本数据进行转换。但是,我得不到满意的结果。
如果我简单地打印使用 [=14=] 获得的文本,它看起来与滚动文本数据完全一样。现在我想用 for
循环逐行读取它,并用 strip
和 split
命令将它分开。基本上与我直接从文件中读取时的方式相同,但它不起作用。
输入数据包含大量空格:
" 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"):
...