1
* 파이썬에서 * txt 파일을 기반으로하는 함수를 그려야합니다. 파일에는 첫 번째 열에 20 x 값 (x 범위는 -10에서 10까지)이 포함되고 다음 열에는 20 개의 y 값이 포함됩니다. 나는 파일 열기 버튼으로 창을 만들었고 축도 그려 봤습니다. 유일한 문제는 txt 파일에서 읽은 값이 프로그램의 좌표와 일치하지 않는다는 것입니다. 이건 내 코드입니다 :tkinter를 사용하는 파이썬의 그래프 플롯
import tkinter as tk
import tkinter.filedialog
class Program(tk.Frame,tk.Canvas):
def __init__(self, parent):
tk.Frame.__init__(self, parent)
self.parent = parent
self.kanwa = tk.Canvas(self)
self.kanwa.pack(fill=tk.BOTH, expand=1)
self.initUI()
self.rys_osi()
self.znaczniki()
def initUI(self):
self.parent.title("Program")
self.pack(fill=tk.BOTH, expand=1)
menubar = tk.Menu(self.parent)
self.parent.config(menu=menubar)
fileMenu = tk.Menu(menubar)
fileMenu.add_command(label="Otwórz", command=self.otworz_plik)
menubar.add_cascade(label="Plik", menu=fileMenu)
self.kanwa.create_text(5, 5, anchor=tk.NW, font="Helvetica 18 bold", fill="blue", text="Wykres funkcji") #tytul
self.kanwa.create_text(780, 270, font="Helvetica 14 bold", fill="black", text="0X") #tytul OX
def rys_osi(self):
self.kanwa.create_line(400, 600, 400, 0, arrow=tk.LAST, arrowshape=(13,17,6), width=3) #os y (x0,y0,x1,y1), grubosc 3px
self.kanwa.create_line(0, 300, 800, 300, arrow=tk.LAST, arrowshape=(13,17,6), width=3) #os x, domyslny arrowshape (d1,d2,d3=8,10,3)
def znaczniki(self):
for i in range(21):
x = i * 38
self.kanwa.create_line(x+20,310,x+20,290, width=2) #rysowanie znacznikow na osi x
for j in range(21):
y = j * 27
self.kanwa.create_line(410,y+30,390,y+30, width=2) #rysowanie znacznikow na osi y
def otworz_plik(self):
typ_pliku = [('Pliki tekstowe', '*.txt'), ('Wszystkie pliki', '*')] #domyslny typ pliku - *txt
dlg = tk.filedialog.Open(self, filetypes = typ_pliku)
fl = dlg.show()
if fl != '':
text = self.czytaj_plik(fl)
self.konwersja(text)
def czytaj_plik(self, filename):
f = open(filename, "r")
text = f.read()
return text
def konwersja(self, text): #OPERACJE NA WCZYTANYCH PUNTACH
x = [line.split()[0] for line in text.splitlines()] #podział wiersza na wartości x i y
y = [line.split()[1] for line in text.splitlines()]
x1 = [float(arg) for arg in x] #konwersja x -> float
y1 = [float(arg) for arg in y] #konwersja y -> float
punkty = zip (x1,y1) #punkty (x,y) zzipowane funkcja
arg = max(abs(min(y1)),max(y1)) #maksymalna wartosc y
skala = arg/10 #podziel max wart y przez 10 - uzyskuje podzialke
wart_y = []
for i in range (11): #petla wpisujaca wartosci skali y do listy wart_y
wart_y.append(i) #inicjalizacja listy ???
wart_y[i]=skala*i
wart_y.reverse() #odwrocenie kolejnosci argumentow w liscie
print(x)
print(y)
print (arg,"MAX Y")
print(wart_y)
self.etykiety_x(x)
self.etykiety_y(wart_y)
self.rysuj(x1,y1)
def etykiety_x(self,x):
for i in range(21):
q = i * 38
self.kanwa.create_text(q+15, 320, font="Helvetica 10", fill="black", text=x[i]) #etykiety osi x - po prostu nazywa od stringow
def etykiety_y(self,wart_y):
for i in range(11):
q = i * 27
self.kanwa.create_text(430, q+30, font="Helvetica 10", fill="black", text=wart_y[i]) #etykiety osi y - dodatnie
j = 9
while j >= 0:
u = j * 27
self.kanwa.create_text(430, 570-u, font="Helvetica 10", fill="black", text=wart_y[j]) #etykiety osi y - ujemne
j=j-1
print(j,wart_y[j])
def rysuj(self,x1,y1):
punkty = []
punkty = zip(x1,y1)
self.kanwa.create_line(*punkty, fill='red', width = 3)
def main():
app = tk.Tk()
Program(app)
app.geometry("800x600") #rozmiar okna
app.mainloop()
if __name__ == '__main__':
main()
그리고 들으 파일은 다음과 같습니다
-10 150
-9 114
...
10 190
내가 코딩 매우 초보자, 그래서 내가 좌표하는 함수 값을 은밀한 방법을 모른다 화면. 같이
if __name__ == '__main__': main()
정확히 지금은 도움이되지 않지만, 'tkinter'는 수학적 플롯을 만들 때 고통 스럽습니다. 대신에'matplotlib'을 사용하십시오 : http://matplotlib.org/, 적어도 미래 프로젝트를 위해서. –
예, 알지만, 외부 라이브러리를 사용하지 않고이 작업을 수행해야합니다. –