Tkinter का Text
विजेट आपके GUI अनुप्रयोगों में बहु-पंक्ति पाठ इनपुट को संभालने का एक शक्तिशाली तरीका प्रदान करता है। यह लेख प्रभावी ढंग से इस इनपुट को पुनः प्राप्त करने और प्रबंधित करने के तरीके का पता लगाता है, जिसमें आवश्यक तकनीकें और सर्वोत्तम अभ्यास शामिल हैं।
विषय-सूची
- Tkinter टेक्स्ट विजेट को समझना
get()
विधि के साथ टेक्स्ट पुनः प्राप्त करना- प्रारंभ और अंत सूचकांक निर्दिष्ट करना
- इनपुट सत्यापन और त्रुटि संचालन
- उन्नत तकनीकें
- अक्सर पूछे जाने वाले प्रश्न
Tkinter टेक्स्ट विजेट को समझना
Tkinter का Text
विजेट एक साधारण एकल-पंक्ति इनपुट से आगे बढ़ता है; यह आपके अनुप्रयोग के भीतर एक पूरी तरह से कार्यात्मक टेक्स्ट एडिटर है। उपयोगकर्ता कई पंक्तियाँ इनपुट कर सकते हैं, स्वरूपण लागू कर सकते हैं (अतिरिक्त कॉन्फ़िगरेशन की आवश्यकता होती है), और यहां तक कि छवियों को भी सम्मिलित कर सकते हैं (उपयुक्त सेटअप के साथ)। इसकी सामग्री को प्रभावी ढंग से पुनः प्राप्त करने के लिए इसकी टेक्स्ट इंडेक्सिंग प्रणाली में महारत हासिल करना महत्वपूर्ण है।
get()
विधि के साथ टेक्स्ट पुनः प्राप्त करना
get()
विधि टेक्स्ट पुनः प्राप्त करने के लिए मौलिक है। यह दो तर्क स्वीकार करता है: प्रारंभ और अंत सूचकांक, निकालने वाले टेक्स्ट भाग को परिभाषित करते हैं। सूचकांक line.character
प्रारूप का पालन करते हैं (पंक्ति संख्याएँ 1 से शुरू होती हैं, वर्ण 0 से)।
सभी टेक्स्ट को पुनः प्राप्त करने के लिए:
import tkinter as tk
root = tk.Tk()
text_box = tk.Text(root, height=10, width=30)
text_box.pack()
def get_all_text():
text = text_box.get("1.0", tk.END)
print(text)
button = tk.Button(root, text="Get All Text", command=get_all_text)
button.pack()
root.mainloop()
"1.0"
पहले वर्ण का प्रतिनिधित्व करता है, और "end"
अंतिम का। ध्यान दें कि आउटपुट में अनुगामी न्यूलाइन वर्ण शामिल हैं; उन्हें निकालने के लिए .strip()
का उपयोग करें।
प्रारंभ और अंत सूचकांक निर्दिष्ट करना
सटीक नियंत्रण के लिए, सीधे सूचकांक निर्दिष्ट करें। उदाहरण के लिए, दूसरी पंक्ति के तीसरे वर्ण से पाँचवीं पंक्ति के अंत तक टेक्स्ट प्राप्त करने के लिए:
text = text_box.get("2.2", "5.end")
उपयोगी सूचकांक नामों में "insert"
(कर्सर स्थिति), "sel.first"
और "sel.last"
(चयन सीमाएँ) शामिल हैं।
इनपुट सत्यापन और त्रुटि संचालन
प्रसंस्करण से पहले इनपुट को मान्य करना महत्वपूर्ण है। इसमें लंबाई, प्रारूप या निषिद्ध वर्णों की जाँच करना शामिल हो सकता है। अपने कमांड फ़ंक्शन के भीतर या उपयोगकर्ता इनपुट के बाद (जैसे, एंटर कुंजी दबाना) सत्यापन करें।
def validate_input():
text = text_box.get("1.0", tk.END).strip()
if not text:
print("कृपया कुछ टेक्स्ट दर्ज करें।")
return
if len(text) > 100:
print("इनपुट बहुत लंबा है।")
return
# मान्य टेक्स्ट को संसाधित करें
print("मान्य टेक्स्ट:", text)
मजबूत अनुप्रयोग संभावित त्रुटियों को संभालते हैं। जबकि get()
शायद ही कभी अपवाद देता है, अमान्य सूचकांक समस्याएँ पैदा कर सकते हैं। सुचारू त्रुटि संचालन के लिए try-except
ब्लॉक का उपयोग करें।
उन्नत तकनीकें
अपने Tkinter टेक्स्ट हैंडलिंग को बढ़ाने के लिए इन उन्नत तकनीकों का पता लगाएँ:
- टैगिंग: विशिष्ट टेक्स्ट भागों को स्वरूपित करने के लिए टैग लागू करें।
- टेक्स्ट संशोधन: टेक्स्ट को सीधे हेरफेर करने के लिए
insert()
,delete()
औरreplace()
जैसी विधियों का उपयोग करें। - बंधन: वास्तविक समय इनपुट प्रसंस्करण के लिए ईवेंट बाइंडिंग (जैसे,
<KeyPress>
) का उपयोग करें।
अक्सर पूछे जाने वाले प्रश्न
- प्रश्न: मैं अनुगामी न्यूलाइन वर्ण कैसे निकालूँ?
उत्तर:.strip()
का उपयोग करें:text = text_box.get("1.0", tk.END).strip()
- प्रश्न: मुझे पंक्तियों की संख्या कैसे मिलेगी?
उत्तर: न्यूलाइन वर्णों (n
) को गिनें या अंतिम न्यूलाइन से पहले अंतिम वर्ण के सूचकांक को प्राप्त करने के लिएtext_box.index("end-1c")
का उपयोग करें, इस सूचकांक से पंक्ति संख्या निकालें। - प्रश्न: मैं टेक्स्ट पुनर्प्राप्ति के दौरान त्रुटियों को कैसे संभालूँ?
उत्तर: अपनेget()
कॉल कोtry-except
ब्लॉक में लपेटें।