PyQt5 - त्वरित गाइड

PyQt एक GUI विजेट टूलकिट है। यह एक पायथन इंटरफ़ेस हैQtसबसे शक्तिशाली और लोकप्रिय क्रॉस-प्लेटफ़ॉर्म GUI लाइब्रेरी में से एक है। PyQt नदी किनारे कम्प्यूटिंग लिमिटेड द्वारा विकसित किया गया था PyQt के नवीनतम संस्करण को अपनी आधिकारिक वेबसाइट से डाउनलोड किया जा सकता है - riverbankcomputing.com

PyQt एपीआई बड़ी संख्या में वर्गों और कार्यों वाले मॉड्यूल का एक सेट है। जबकिQtCore मॉड्यूल में फ़ाइल और निर्देशिका आदि के साथ काम करने के लिए गैर-जीयूआई कार्यक्षमता शामिल है, QtGuiमॉड्यूल में सभी ग्राफिकल नियंत्रण शामिल हैं। इसके अलावा, एक्सएमएल के साथ काम करने के लिए मॉड्यूल हैं(QtXml), एसवीजी (QtSvg)और एसक्यूएल (QtSql), आदि।

अक्सर उपयोग किए जाने वाले मॉड्यूल की एक सूची नीचे दी गई है -

  • QtCore - कोर गैर-जीयूआई कक्षाएं अन्य मॉड्यूल द्वारा उपयोग की जाती हैं

  • QtGui - ग्राफिकल यूजर इंटरफेस घटक

  • QtMultimedia - निम्न-स्तरीय मल्टीमीडिया प्रोग्रामिंग के लिए कक्षाएं

  • QtNetwork - नेटवर्क प्रोग्रामिंग के लिए कक्षाएं

  • QtOpenGL - ओपनगैल सपोर्ट क्लासेस

  • QtScript - क्यूटी लिपियों के मूल्यांकन के लिए कक्षाएं

  • QtSql एसक्यूएल का उपयोग कर डेटाबेस एकीकरण के लिए कक्षाएं

  • QtSvg - एसवीजी फ़ाइलों की सामग्री को प्रदर्शित करने के लिए कक्षाएं

  • QtWebKit - HTML के प्रतिपादन और संपादन के लिए कक्षाएं

  • QtXml - एक्सएमएल से निपटने के लिए कक्षाएं

  • QtWidgets - क्लासिक डेस्कटॉप शैली यूआई बनाने के लिए कक्षाएं

  • QtDesigner - क्यूटी डिजाइनर का विस्तार करने के लिए कक्षाएं

सहायक वातावरण

PyQt विंडोज, लिनक्स और मैक ओएस सहित सभी लोकप्रिय ऑपरेटिंग सिस्टम के साथ संगत है। यह दोहरे लाइसेंस वाला है, जो जीपीएल के साथ-साथ वाणिज्यिक लाइसेंस के तहत उपलब्ध है। नवीनतम स्थिर संस्करण हैPyQt5-5.13.2.

खिड़कियाँ

32-बिट या 64-बिट आर्किटेक्चर के लिए पहियों को प्रदान किया जाता है जो पायथन संस्करण 3.5 या उसके बाद के अनुरूप हैं। इंस्टॉल करने का अनुशंसित तरीका उपयोग कर रहा हैPIP उपयोगिता -

pip3 install PyQt5

PyQt5 पहियों का समर्थन करने के लिए Qt डिज़ाइनर जैसे विकास उपकरण स्थापित करने के लिए, निम्नलिखित आदेश है -

pip3 install pyqt5-tools

आप स्रोत कोड www.riverbankcomputing.com/static/Downloads/PyQt5 से Linux / macOS पर PyQt5 भी बना सकते हैं

PyQt5 API पहले के संस्करणों के साथ स्वचालित रूप से संगत नहीं है। इसलिए, प्रासंगिक बदलाव करके PyQt4 मॉड्यूल वाले पायथन कोड को मैन्युअल रूप से अपग्रेड किया जाना चाहिए। इस अध्याय में, PyQt4 और PyQt5 के बीच मुख्य अंतर सूचीबद्ध किए गए हैं।

PyQt5 पहले v2.6 की तुलना में पायथन के संस्करणों पर समर्थित नहीं है।

PyQt5 सिग्नल और स्लॉट के बीच संबंध के लिए QObject क्लास के कनेक्ट () पद्धति का समर्थन नहीं करता है। इसलिए उपयोग को और अधिक लागू नहीं किया जा सकता है -

QObject.connect(widget, QtCore.SIGNAL(‘signalname’), slot_function)

केवल निम्नलिखित सिंटैक्स को परिभाषित किया गया है -

widget.signal.connect(slot_function)

पहले QtGui मॉड्यूल में परिभाषित कक्षाएं वितरित की गई हैं QtGui, QtPrintSupport एक QtWidgets मॉड्यूल।

नए QFileDialog वर्ग में, द getOpenFileNameAndFilter() विधि द्वारा प्रतिस्थापित किया जाता है getOpenFileName(), getOpenFileNamesAndFilter() द्वारा getOpenFileNames() तथा getSaveFileNameAndFilter() द्वारा getSaveFileName()। इन विधियों के पुराने हस्ताक्षर भी बदल गए हैं।

PyQt5 में एक वर्ग को परिभाषित करने का प्रावधान नहीं है जो एक से अधिक Qt वर्ग से उप-वर्गीय है।

pyuic5 उपयोगिता (डिज़ाइनर की XML फ़ाइल से पायथन कोड उत्पन्न करने के लिए) --pyqt3-आवरण फ्लैग का समर्थन नहीं करता है।

pyrcc5-py2 और -py3 झंडे का समर्थन नहीं करता है। Pyrcc5 का आउटपुट पाइथन v2.6 के सभी संस्करणों के साथ संगत है।

PyQt5 हमेशा आक्रमण करता है sip.setdestroyonexit() स्वचालित रूप से और सभी लिपटे उदाहरणों के सी ++ विध्वंसक को कॉल करता है जो इसके मालिक हैं।

PyQt का उपयोग करके एक सरल GUI एप्लिकेशन बनाना निम्नलिखित चरणों में शामिल है -

  • PyQt5 पैकेज से QtCore, QtGui और QtWidgets मॉड्यूल आयात करें।

  • QApplication class का एक एप्लिकेशन ऑब्जेक्ट बनाएं।

  • QWidget ऑब्जेक्ट शीर्ष स्तर की विंडो बनाता है। इसमें QLabel ऑब्जेक्ट जोड़ें।

  • लेबल के कैप्शन को "हैलो वर्ल्ड" के रूप में सेट करें।

  • SetGeometry () विधि द्वारा विंडो के आकार और स्थिति को परिभाषित करें।

  • द्वारा आवेदन का मुख्य भाग दर्ज करें app.exec_() तरीका।

निम्नलिखित PyQt में हैलो वर्ल्ड प्रोग्राम निष्पादित करने के लिए कोड है -

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
def window():
   app = QApplication(sys.argv)
   w = QWidget()
   b = QLabel(w)
   b.setText("Hello World!")
   w.setGeometry(100,100,200,50)
   b.move(50,20)
   w.setWindowTitle("PyQt5")
   w.show()
   sys.exit(app.exec_())
if __name__ == '__main__':
   window()

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

उपरोक्त कोड का एक वस्तु उन्मुख समाधान विकसित करना भी संभव है।

  • PyQt5 पैकेज से QtCore, QtGui और QtWidgets मॉड्यूल आयात करें।

  • QApplication class का एक एप्लिकेशन ऑब्जेक्ट बनाएं।

  • QWidget क्लास के आधार पर विंडो क्लास घोषित करें

  • QLabel ऑब्जेक्ट जोड़ें और लेबल के कैप्शन को "हैलो वर्ल्ड" के रूप में सेट करें।

  • SetGeometry () विधि द्वारा विंडो के आकार और स्थिति को परिभाषित करें।

  • द्वारा आवेदन का मुख्य भाग दर्ज करें app.exec_() तरीका।

निम्नलिखित वस्तु उन्मुख समाधान का पूरा कोड है -

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
class window(QWidget):
   def __init__(self, parent = None):
      super(window, self).__init__(parent)
      self.resize(200,50)
      self.setWindowTitle("PyQt5")
      self.label = QLabel(self)
      self.label.setText("Hello World")
      font = QFont()
      font.setFamily("Arial")
      font.setPointSize(16)
      self.label.setFont(font)
      self.label.move(50,20)
def main():
   app = QApplication(sys.argv)
   ex = window()
   ex.show()
   sys.exit(app.exec_())
if __name__ == '__main__':
   main()

PyQt APIकक्षाओं और विधियों का एक बड़ा संग्रह है। इन वर्गों को 20 से अधिक मॉड्यूल में परिभाषित किया गया है।

निम्नलिखित अक्सर उपयोग किए जाने वाले कुछ मॉड्यूल हैं -

अनु क्रमांक। मॉड्यूल और विवरण
1

QtCore

कोर गैर-जीयूआई कक्षाएं अन्य मॉड्यूल द्वारा उपयोग की जाती हैं

2

QtGui

ग्राफिकल यूजर इंटरफेस घटक

3

QtMultimedia

निम्न-स्तरीय मल्टीमीडिया प्रोग्रामिंग के लिए कक्षाएं

4

QtNetwork

नेटवर्क प्रोग्रामिंग के लिए कक्षाएं

5

QtOpenGL

ओपनगेल सपोर्ट क्लासेस

6

QtScript

क्यूटी लिपियों के मूल्यांकन के लिए कक्षाएं

7

QtSql

SQL का उपयोग करके डेटाबेस एकीकरण के लिए कक्षाएं

8

QtSvg

एसवीजी फ़ाइलों की सामग्री प्रदर्शित करने के लिए कक्षाएं

9

QtWebKit

HTML के प्रतिपादन और संपादन के लिए कक्षाएं

10

QtXml

एक्सएमएल से निपटने के लिए कक्षाएं

1 1

QtWidgets

क्लासिक डेस्कटॉप शैली UI बनाने के लिए कक्षाएं।

12

QtDesigner

क्यूटी डिजाइनर का विस्तार करने के लिए कक्षाएं

13

QtAssistant

ऑनलाइन मदद के लिए समर्थन

PyQt5 विकास उपकरण क्यूटी विकास के लिए उपयोगी उपयोगिताओं का एक संग्रह है। निम्नलिखित ऐसी उपयोगिताओं की एक चयनित सूची है -

अनु क्रमांक। उपकरण का नाम और विवरण
1

assistant

Qt सहायक प्रलेखन उपकरण

2

pyqt5designer

क्यूटी डिजाइनर जीयूआई लेआउट टूल

3

linguist

Qt भाषाई अनुवाद उपकरण

4

lrelease

ts फ़ाइलों को qm फ़ाइलों के लिए संकलित करें

5

pylupdate5

अनुवाद स्ट्रिंग्स निकालें और ts फ़ाइलों को जनरेट या अपडेट करें

6

qmake

Qt सॉफ्टवेयर बिल्ड टूल

7

pyqt5qmlscene

QML फ़ाइल दर्शक

8

pyqmlviewer

QML फ़ाइल दर्शक

9

pyrcc5

Qt संसाधन फ़ाइल संकलक

10

pyuic5

क्यूटी यूजर इंटरफेस कंपाइलर ui फाइलों से कोड जनरेट करने के लिए

1 1

pyqmltestrunner

QML कोड पर यूनिट परीक्षण चल रहा है

12

qdbus

डी-बस सेवाओं को सूचीबद्ध करने के लिए कमांड-लाइन टूल

13

QDoc

सॉफ्टवेयर परियोजनाओं के लिए प्रलेखन जनरेटर।

14

Qhelpgenerator

Qt सहायता फ़ाइलों को बनाना और देखना।

15

qmlimportscanner

QML आयात पर पर्स और रिपोर्ट

PyQt API में 400 से अधिक कक्षाएं हैं। QObjectवर्ग पदानुक्रम के शीर्ष पर है। यह सभी Qt वस्तुओं का आधार वर्ग है। साथ ही,QPaintDevice वर्ग सभी वस्तुओं के लिए आधार वर्ग है जिसे चित्रित किया जा सकता है।

QApplicationक्लास मुख्य सेटिंग्स और GUI एप्लिकेशन के नियंत्रण प्रवाह का प्रबंधन करता है। इसमें मुख्य ईवेंट लूप होता है जिसके अंदर विंडो तत्वों और अन्य स्रोतों से उत्पन्न घटनाओं को संसाधित और प्रेषित किया जाता है। यह सिस्टम-वाइड और एप्लिकेशन-वाइड सेटिंग्स को भी हैंडल करता है।

QWidget वर्ग, QObject और QPaintDevice वर्गों से प्राप्त सभी उपयोगकर्ता इंटरफ़ेस ऑब्जेक्ट के लिए आधार वर्ग है। QDialog तथा QFrameकक्षाएं भी QWidget वर्ग से ली गई हैं। उनकी अपनी उप-वर्ग प्रणाली है।

यहाँ अक्सर उपयोग किए जाने वाले विगेट्स की एक सूची है

अनु क्रमांक। विजेट और विवरण
1

QLabel

पाठ या छवि प्रदर्शित करने के लिए उपयोग किया जाता है

2

QLineEdit

उपयोगकर्ता को पाठ की एक पंक्ति में प्रवेश करने की अनुमति देता है

3

QTextEdit

उपयोगकर्ता को बहु-पंक्ति पाठ दर्ज करने की अनुमति देता है

4

QPushButton

कार्रवाई करने के लिए एक कमांड बटन

5

QRadioButton

कई विकल्पों में से एक को चुनने में सक्षम करता है

6

QCheckBox

एक से अधिक विकल्पों की पसंद को सक्षम करता है

7

QSpinBox

पूर्णांक मान को बढ़ाने / घटाने में सक्षम करता है

8

QScrollBar

प्रदर्शन एपर्चर से परे एक विजेट की सामग्री का उपयोग करने में सक्षम बनाता है

9

QSlider

बाध्य मान को रैखिक रूप से बदलने में सक्षम करता है।

10

QComboBox

से चुनने के लिए मदों की एक ड्रॉपडाउन सूची प्रदान करता है

1 1

QMenuBar

क्षैतिज बार QMenu वस्तुओं को पकड़े हुए

12

QStatusBar

आमतौर पर QMainWindow के निचले भाग में, स्थिति की जानकारी प्रदान करता है।

13

QToolBar

आमतौर पर QMainWindow या फ्लोटिंग के शीर्ष पर। एक्शन बटन शामिल हैं

14

QListView

ListMode या IconMode में आइटमों की चयन सूची प्रदान करता है

15

QPixmap

QLabel या QPushButton ऑब्जेक्ट पर प्रदर्शन के लिए ऑफ-स्क्रीन छवि प्रतिनिधित्व

16

QDialog

मोडल या मॉडलस विंडो जो मूल विंडो पर जानकारी लौटा सकती है

एक सामान्य GUI आधारित एप्लिकेशन का शीर्ष स्तर विंडो द्वारा बनाया गया है QMainWindowविजेट वस्तु। ऊपर सूचीबद्ध कुछ विजेट इस मुख्य विंडो में अपनी नियुक्त जगह लेते हैं, जबकि अन्य को विभिन्न लेआउट प्रबंधकों का उपयोग करके केंद्रीय विजेट क्षेत्र में रखा जाता है।

निम्नलिखित आरेख QMainWindow रूपरेखा को दर्शाता है -

PyQt इंस्टॉलर एक GUI बिल्डर टूल के साथ आता है Qt Designer। अपने सरल ड्रैग एंड ड्रॉप इंटरफेस का उपयोग करके, कोड लिखने के बिना एक GUI इंटरफ़ेस जल्दी से बनाया जा सकता है। हालाँकि, यह आईडीई नहीं है जैसे कि विजुअल स्टूडियो। इसलिए, Qt डिज़ाइनर के पास एप्लिकेशन को डीबग करने और बनाने की सुविधा नहीं है।

Qt डिज़ाइनर एप्लिकेशन शुरू करें जो विकास उपकरणों का एक हिस्सा है और वर्चुअल वातावरण की स्क्रिप्ट फ़ोल्डर में स्थापित है।

फ़ाइल → नया मेनू चुनकर GUI इंटरफ़ेस डिज़ाइन करना शुरू करें।

फिर आप बाएँ फलक पर विजेट बॉक्स से आवश्यक विजेट्स को खींच और छोड़ सकते हैं। आप प्रपत्र पर रखी गई विजेट के गुणों को भी मान प्रदान कर सकते हैं।

डिज़ाइन किए गए फॉर्म को डेमो के रूप में सहेजा जाता है। इस यूआई फ़ाइल में डिजाइन में विगेट्स के XML प्रतिनिधित्व और उनके गुण शामिल हैं। यह डिज़ाइन pyuic5 कमांड लाइन उपयोगिता का उपयोग करके पायथन के समकक्ष अनुवाद किया गया है। यह उपयोगिता Qt टूलकिट के यूरिक मॉड्यूल के लिए एक आवरण है। Pyuic5 का उपयोग इस प्रकार है -

pyuic5 -x demo.ui -o demo.py

उपरोक्त कमांड में, -x स्विच उत्पन्न पायथन लिपि में (एक्सएमएल से) अतिरिक्त कोड की एक छोटी राशि जोड़ता है ताकि यह एक स्व-निष्पादन योग्य स्टैंडअलोन एप्लिकेशन बन जाए।

if __name__ == "__main__":
   import sys
   app = QtGui.QApplication(sys.argv)
   Dialog = QtGui.QDialog()
   ui = Ui_Dialog()
   ui.setupUi(Dialog)
   Dialog.show()
   sys.exit(app.exec_())

परिणामी अजगर स्क्रिप्ट को निम्नलिखित डायलॉग बॉक्स दिखाने के लिए निष्पादित किया जाता है -

python demo.py

उपयोगकर्ता इनपुट फ़ील्ड में डेटा इनपुट कर सकता है लेकिन ऐड बटन पर क्लिक करने से कोई क्रिया उत्पन्न नहीं होगी क्योंकि यह किसी फ़ंक्शन से संबद्ध नहीं है। उपयोगकर्ता द्वारा उत्पन्न प्रतिक्रिया को प्रतिक्रिया के रूप में कहा जाता हैevent handling

कंसोल मोड एप्लिकेशन के विपरीत, जिसे क्रमिक तरीके से निष्पादित किया जाता है, एक GUI आधारित एप्लिकेशन इवेंट संचालित होता है। उपयोगकर्ता के कार्यों के जवाब में कार्य या विधियों को क्रियान्वित किया जाता है जैसे कि बटन पर क्लिक करना, किसी संग्रह से आइटम का चयन करना या माउस क्लिक आदि, जिसे कहा जाता हैevents

GUI इंटरफ़ेस बनाने के लिए उपयोग किए जाने वाले विजेट ऐसे आयोजनों के स्रोत के रूप में कार्य करते हैं। प्रत्येक PyQt विजेट, जो QObject वर्ग से लिया गया है, का उत्सर्जन करने के लिए डिज़ाइन किया गया है‘signal’एक या अधिक घटनाओं के जवाब में। अपने आप पर संकेत कोई कार्रवाई नहीं करता है। इसके बजाय, यह एक से 'जुड़ा' है‘slot’। स्लॉट कोई भी हो सकता हैcallable Python function

क्यूटी डिज़ाइनर के सिग्नल / स्लॉट संपादक का उपयोग करना

पहले एक लाइनएडिट कंट्रोल और एक पुशबटन के साथ एक सरल रूप तैयार करें।

यह वांछित है कि यदि बटन दबाया जाता है, तो पाठ बॉक्स की सामग्री को मिटा दिया जाना चाहिए। QLineEdit विजेट में इस उद्देश्य के लिए एक स्पष्ट () विधि है। इसलिए, बटनclicked सिग्नल से जुड़ा होना है clear() पाठ बॉक्स की विधि।

इसके साथ शुरू करने के लिए, संपादन मेनू / (या F4 दबाएं) से संकेत / स्लॉट संपादित करें चुनें। फिर माउस से बटन को हाइलाइट करें और कर्सर को टेक्स्टबॉक्स की ओर खींचें

जैसे ही माउस जारी किया जाता है, बटन के संकेत और स्लॉट के तरीकों को दर्शाने वाला एक संवाद प्रदर्शित किया जाएगा। क्लिक किया गया संकेत और स्पष्ट () विधि का चयन करें

नीचे दाईं ओर सिग्नल / स्लॉट संपादक विंडो परिणाम दिखाएगा -

नीचे दिए गए कोड में ui फ़ाइल से ui और बिल्ड और पायथन कोड सहेजें -

pyuic5 -x signalslot.ui -o signalslot.py

उत्पन्न पायथन कोड में निम्नलिखित कथन द्वारा संकेत और स्लॉट के बीच संबंध होगा -

self.pushButton.clicked.connect(self.lineEdit.clear)

Signallot.py चलाएं और LineEdit में कुछ टेक्स्ट डालें। यदि बटन दबाया जाता है, तो पाठ साफ़ हो जाएगा।

बिल्डिंग सिग्नल-स्लॉट कनेक्शन

डिज़ाइनर का उपयोग करने के बजाय, आप सिंटैक्स का अनुसरण करके सीधे सिग्नल-स्लॉट कनेक्शन स्थापित कर सकते हैं -

widget.signal.connect(slot_function)

मान लीजिए कि एक बटन क्लिक करने पर एक फ़ंक्शन को बुलाया जाना है। यहां, क्लिक किए गए सिग्नल को कॉल करने योग्य फ़ंक्शन से जोड़ा जाना है। इसे निम्नलिखित में से किसी तकनीक में प्राप्त किया जा सकता है -

button.clicked.connect(slot_function)

उदाहरण

निम्न उदाहरण में, QDialog विंडो में दो QPushButton ऑब्जेक्ट्स (b1 और b2) जोड़े गए हैं। हम क्रमशः b1 और b2 पर क्लिक करके फ़ंक्शन बी 1_क्लिप्ड () और बी 2_क्लिप्ड () कॉल करना चाहते हैं।

जब b1 क्लिक किया जाता है, तो क्लिक किया गया () सिग्नल b1_clicked () फ़ंक्शन से जुड़ा होता है -

b1.clicked.connect(b1_clicked())

जब b2 क्लिक किया जाता है, तो क्लिक किया हुआ () सिग्नल b2_clicked () फ़ंक्शन से जुड़ा होता है।

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

def window():
   app = QApplication(sys.argv)
   win = QDialog()
   b1 = QPushButton(win)
   b1.setText("Button1")
   b1.move(50,20)
   b1.clicked.connect(b1_clicked)
   
   b2 = QPushButton(win)
   b2.setText("Button2")
   b2.move(50,50)
   b2.clicked.connect(b2_clicked)
   
   win.setGeometry(100,100,200,100)

   win.setWindowTitle("PyQt5")
   win.show()
   sys.exit(app.exec_())

def b1_clicked():
   print ("Button 1 clicked")

def b2_clicked():
   print ("Button 2 clicked")

if __name__ == '__main__':
   window()

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

उत्पादन

Button 1 clicked
Button 2 clicked

एक GUI विजेट को पिक्सेल विंडो में मापा जा सकता है, जो इसके पूर्ण निर्देशांक को पिक्सेल में मापा जाता है। निर्देशांक setGeometry () विधि द्वारा परिभाषित विंडो के आयामों के सापेक्ष हैं।

setGeometry () सिंटैक्स

QWidget.setGeometry(xpos, ypos, width, height)

निम्नलिखित कोड स्निपेट में, मॉनिटर द्वारा स्थिति (10, 10) में 300 बाय 200 पिक्सेल आयामों की शीर्ष स्तर विंडो प्रदर्शित की जाती है।

import sys
from PyQt4 import QtGui

def window():
   app = QtGui.QApplication(sys.argv)
   w = QtGui.QWidget()
	
   b = QtGui.QPushButton(w)
   b.setText("Hello World!")
   b.move(50,20)
	
   w.setGeometry(10,10,300,200)
   w.setWindowTitle(“PyQt”)
   w.show()
   sys.exit(app.exec_())
	
if __name__ == '__main__':
   window()

PushButton विजेट को विंडो में जोड़ा जाता है और उसे 50 पिक्सेल दाईं ओर रखा जाता है और खिड़की के ऊपरी बाएँ स्थान से 20 पिक्सेल नीचे।

हालांकि, यह पूर्ण स्थिति निम्नलिखित कारणों से उपयुक्त नहीं है -

  • विंडो के आकार बदलने पर भी विजेट की स्थिति नहीं बदलती है।

  • अलग-अलग रिज़ॉल्यूशन वाले विभिन्न डिस्प्ले डिवाइस पर उपस्थिति एक समान नहीं हो सकती है।

  • लेआउट में संशोधन कठिन है क्योंकि इसे पूरे फॉर्म को फिर से डिज़ाइन करने की आवश्यकता हो सकती है।

PyQt एपीआई कंटेनर के अंदर विजेट्स की स्थिति के अधिक सुरुचिपूर्ण प्रबंधन के लिए लेआउट कक्षाएं प्रदान करता है। पूर्ण स्थिति पर लेआउट प्रबंधकों के फायदे हैं -

  • विंडो के अंदर विजेट स्वचालित रूप से आकार परिवर्तन कर रहे हैं।

  • विभिन्न प्रस्तावों के साथ प्रदर्शन उपकरणों पर एक समान उपस्थिति सुनिश्चित करता है।

  • रीडायरेक्ट किए बिना विजेट को गतिशील रूप से जोड़ना या हटाना संभव है।

Qt टूलकिट विभिन्न लेआउट्स को परिभाषित करता है जिनका उपयोग Qt डिज़ाइनर उपयोगिता के साथ किया जा सकता है।

यहां उन वर्गों की सूची दी गई है, जिनके बारे में हम इस अध्याय में एक-एक करके चर्चा करेंगे।

अनु क्रमांक। कक्षाएं और विवरण
1 QBoxLayout

QBoxLayout वर्ग विगेट्स को लंबवत या क्षैतिज रूप से बढ़ाता है। इसके व्युत्पन्न वर्ग QVBoxLayout हैं (विगेट्स को व्यवस्थित रूप से व्यवस्थित करने के लिए) और QHBoxLayout (विगेट्स को क्षैतिज रूप से व्यवस्थित करने के लिए)।

2 QGridLayout

GridLayout वर्ग ऑब्जेक्ट पंक्तियों और स्तंभों में व्यवस्थित कोशिकाओं की एक ग्रिड के साथ प्रस्तुत करता है। वर्ग में ऐडविजेट () विधि है। सेल की पंक्तियों और स्तंभों की संख्या निर्दिष्ट करके किसी भी विजेट को जोड़ा जा सकता है।

3 QFormLayout

QFormLayout दो कॉलम फॉर्म बनाने का एक सुविधाजनक तरीका है, जहां प्रत्येक पंक्ति में एक लेबल के साथ जुड़े इनपुट फ़ील्ड होते हैं। एक सम्मेलन के रूप में, बाएं कॉलम में लेबल होता है और दाएं कॉलम में एक इनपुट फ़ील्ड होती है।

यहां उन विजेट्स की सूची दी गई है, जिनके बारे में हम इस अध्याय में एक-एक करके चर्चा करेंगे।

अनु क्रमांक विजेट और विवरण
1 QLabel

QLabel ऑब्जेक्ट गैर-संपादन योग्य पाठ या छवि, या एनिमेटेड GIF की मूवी प्रदर्शित करने के लिए एक प्लेसहोल्डर के रूप में कार्य करता है। इसे अन्य विगेट्स के लिए एक मेनमोनिक कुंजी के रूप में भी इस्तेमाल किया जा सकता है।

2 QLineEdit

QLineEdit ऑब्जेक्ट सबसे अधिक इस्तेमाल किया जाने वाला इनपुट फ़ील्ड है। यह एक बॉक्स प्रदान करता है जिसमें पाठ की एक पंक्ति दर्ज की जा सकती है। बहु-पंक्ति पाठ में प्रवेश करने के लिए, क्यूटेक्स्टडिट ऑब्जेक्ट की आवश्यकता होती है।

3 QPushButton

PyQt API में, QPushButton क्लास ऑब्जेक्ट एक बटन प्रस्तुत करता है जिसे क्लिक करने पर एक निश्चित फ़ंक्शन को इनवॉइस करने के लिए प्रोग्राम किया जा सकता है।

4 QRadioButton

एक QRadioButton क्लास ऑब्जेक्ट एक टेक्स्ट लेबल के साथ एक चयन योग्य बटन प्रस्तुत करता है। उपयोगकर्ता प्रपत्र पर प्रस्तुत कई विकल्पों में से एक का चयन कर सकता है। यह वर्ग QAbstractButton वर्ग से लिया गया है।

5 QCheckBox

पाठ लेबल से पहले एक आयताकार बॉक्स प्रकट होता है जब QCheckBox ऑब्जेक्ट को मूल विंडो में जोड़ा जाता है। QRadioButton की तरह, यह भी एक चयन करने योग्य बटन है।

6 QComboBox

QComboBox ऑब्जेक्ट से चुनने के लिए आइटम की एक ड्रॉपडाउन सूची प्रस्तुत करता है। यह केवल वर्तमान में चयनित आइटम को प्रदर्शित करने के लिए आवश्यक फॉर्म पर न्यूनतम स्क्रीन स्थान लेता है।

7 QSpinBox

एक QSpinBox ऑब्जेक्ट उपयोगकर्ता को एक टेक्स्टबॉक्स के साथ प्रस्तुत करता है जो अपने दाईं ओर ऊपर / नीचे बटन के साथ पूर्णांक प्रदर्शित करता है।

8 QSlider विजेट और सिग्नल

QSlider वर्ग ऑब्जेक्ट उपयोगकर्ता को एक खांचे के साथ प्रस्तुत करता है जिस पर एक हैंडल को स्थानांतरित किया जा सकता है। यह एक बंधे हुए मूल्य को नियंत्रित करने के लिए एक क्लासिक विजेट है।

9 QMenuBar, QMenu और QAction

QMainWindow ऑब्जेक्ट के शीर्षक बार के ठीक नीचे एक क्षैतिज QMenuBar QMenu ऑब्जेक्ट प्रदर्शित करने के लिए आरक्षित है।

10 QToolBar

एक क्यूटलबार विजेट एक चल पैनल है जिसमें टेक्स्ट बटन, आइकन या अन्य विजेट के साथ बटन होते हैं।

1 1 QInputDialog

यह एक प्री-कॉन्फ़िगर डायलॉग है जिसमें टेक्स्ट फ़ील्ड और दो बटन हैं, ठीक है और रद्द करें। ओके बटन पर यूजर क्लिक करने या एंटर दबाने के बाद पैरेंट विंडो टेक्स्ट बॉक्स में इनपुट जमा करता है।

12 QFontDialog

एक अन्य आमतौर पर इस्तेमाल किया जाने वाला संवाद, एक फ़ॉन्ट चयनकर्ता विजेट QDialog वर्ग की दृश्य उपस्थिति है। इस संवाद का परिणाम एक Qfont ऑब्जेक्ट है, जिसे मूल विंडो द्वारा उपभोग किया जा सकता है।

13 QFileDialog

यह विजेट एक फ़ाइल चयनकर्ता संवाद है। यह उपयोगकर्ता को फ़ाइल सिस्टम के माध्यम से नेविगेट करने और खोलने या सहेजने के लिए फ़ाइल का चयन करने में सक्षम बनाता है। संवाद स्थिर कार्यों के माध्यम से या डायलॉग ऑब्जेक्ट पर exec_ () फ़ंक्शन को कॉल करके किया जाता है।

14 QTab

यदि किसी प्रपत्र में बहुत सारे फ़ील्ड एक साथ प्रदर्शित किए जाते हैं, तो उन्हें अलग टैब के प्रत्येक टैब के नीचे रखे गए विभिन्न पृष्ठों में व्यवस्थित किया जा सकता है। QTabWidget एक टैब बार और एक पृष्ठ क्षेत्र प्रदान करता है।

15 QStacked

QStackedWidget का कामकाज QTabWidget के समान है। यह विंडो के क्लाइंट क्षेत्र के कुशल उपयोग में भी मदद करता है।

16 QSplitter

यह एक और उन्नत लेआउट प्रबंधक है जो बाल विगेट्स के आकार को गतिशील रूप से उनके बीच की सीमाओं को खींचकर बदलने की अनुमति देता है। स्प्लिटर नियंत्रण एक हैंडल प्रदान करता है जिसे नियंत्रणों का आकार बदलने के लिए खींचा जा सकता है।

17 QDock

एक डॉक करने योग्य विंडो एक सबविंडो है जो फ्लोटिंग स्थिति में रह सकती है या एक निर्दिष्ट स्थान पर मुख्य विंडो से जुड़ी हो सकती है। QMainWindow क्लास की मुख्य विंडो ऑब्जेक्ट में डॉकेबल विंडो के लिए आरक्षित क्षेत्र है।

18 QStatusBar

QMainWindow वस्तु स्थिति पट्टी के रूप में नीचे एक क्षैतिज पट्टी होती है। इसका उपयोग स्थायी या प्रासंगिक स्थिति जानकारी प्रदर्शित करने के लिए किया जाता है।

19 QList

QListWidget वर्ग सूची से आइटम जोड़ने या निकालने के लिए एक आइटम-आधारित इंटरफ़ेस है। सूची में प्रत्येक आइटम एक QListWidgetItem ऑब्जेक्ट है। ListWidget को बहुस्तरीय होने के लिए सेट किया जा सकता है।

20 QScrollBar

स्क्रॉलबार नियंत्रण उपयोगकर्ता को देखने योग्य क्षेत्र के बाहर दस्तावेज़ के कुछ हिस्सों तक पहुंचने में सक्षम बनाता है। यह वर्तमान स्थिति को दृश्य संकेतक प्रदान करता है।

21 QCalendar

QCalendar विजेट एक उपयोगी दिनांक पिकर नियंत्रण है। यह एक महीने का दृश्य प्रदान करता है। उपयोगकर्ता माउस या कीबोर्ड के उपयोग से तारीख का चयन कर सकता है, डिफ़ॉल्ट आज की तारीख है।

QDialogविजेट उपयोगकर्ता से प्रतिक्रिया एकत्र करने के लिए ज्यादातर उपयोग की जाने वाली एक शीर्ष स्तरीय विंडो प्रस्तुत करता है। इसे होने के लिए कॉन्फ़िगर किया जा सकता हैModal (जहां यह अपनी मूल विंडो को ब्लॉक करता है) या Modeless (संवाद विंडो को बायपास किया जा सकता है)।

PyQt API में कई प्री-कॉन्फ़िगर किए गए डायलॉग विजेट्स जैसे InputDialog, FileDialog, FontDogog इत्यादि हैं।

उदाहरण

निम्नलिखित उदाहरण में, WindowModalityडायलॉग विंडो की विशेषता यह तय करती है कि यह मोडल है या मॉडलस। संवाद का कोई भी एक बटन डिफ़ॉल्ट रूप से सेट किया जा सकता है। संवाद द्वारा खारिज कर दिया गया हैQDialog.reject() विधि जब उपयोगकर्ता एस्केप कुंजी दबाता है।

एक शीर्ष स्तर QWidget विंडो पर एक PushButton, जब क्लिक किया जाता है, एक संवाद विंडो का उत्पादन करता है। एक डायलॉग बॉक्स में इसकी शीर्षक पट्टी पर न्यूनतम और अधिकतम नियंत्रण नहीं होता है।

उपयोगकर्ता इस संवाद बॉक्स को पृष्ठभूमि में नहीं हटा सकता क्योंकि इसकी WindowModality सेट है ApplicationModal

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

def window():
   app = QApplication(sys.argv)
   w = QWidget()
   btn = QPushButton(w)
   btn.setText("Hello World!")
   btn.move(100,50)
   btn.clicked.connect(showdialog)
   w.setWindowTitle("PyQt Dialog demo")
   w.show()
   sys.exit(app.exec_())

def showdialog():
   dlg = QDialog()
   b1 = QPushButton("ok",dlg)
   b1.move(50,50)
   dlg.setWindowTitle("Dialog") 9. PyQt5 — QDialog Class
   dlg.setWindowModality(Qt.ApplicationModal)
   dlg.exec_()

if __name__ == '__main__':
   window()

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है। मुख्य विंडो में बटन पर क्लिक करें और डायलॉग बॉक्स पॉप अप करें -

QMessageBoxकुछ सूचना संदेश प्रदर्शित करने के लिए आमतौर पर इस्तेमाल किया जाने वाला मोडल संवाद है और वैकल्पिक रूप से उपयोगकर्ता से किसी भी एक मानक बटन पर क्लिक करके प्रतिक्रिया देने के लिए कहें। प्रत्येक मानक बटन में एक पूर्वनिर्धारित कैप्शन होता है, एक भूमिका और एक पूर्वनिर्धारित हेक्साडेसिमल संख्या देता है।

QMessageBox वर्ग से जुड़े महत्वपूर्ण तरीके और गणना निम्न तालिका में दिए गए हैं -

अनु क्रमांक। तरीके और विवरण
1

setIcon()

संदेश की गंभीरता के अनुरूप पूर्वनिर्धारित आइकन प्रदर्शित करता है

  • Question
  • Information
  • Warning
  • Critical
2

setText()

प्रदर्शित होने के लिए मुख्य संदेश का पाठ सेट करता है

3

setInformativeText()

अतिरिक्त जानकारी प्रदर्शित करता है

4

setDetailText()

डायल एक विवरण बटन दिखाता है। यह पाठ उस पर क्लिक करने पर प्रकट होता है

5

setTitle()

संवाद का कस्टम शीर्षक प्रदर्शित करता है

6

setStandardButtons()

प्रदर्शित होने के लिए मानक बटन की सूची। प्रत्येक बटन के साथ जुड़ा हुआ है

QMessageBox.Ok 0x00000400

QMessageBox.Open 0x00002000

QMessageBox.Save 0x00000800

QMessageBox.Cancel 0x00400000

QMessageBox.Close 0x00200000

QMessageBox.Yes 0x00004000

QMessageBox.No 0x00010000

QMessageBox.Abort 0x00040000

QMessageBox.Retry 0x00080000

QMessageBox.Ignore 0x00100000

7

setDefaultButton()

बटन को डिफ़ॉल्ट के रूप में सेट करता है। यदि Enter दबाया जाता है तो यह क्लिक किए गए सिग्नल का उत्सर्जन करता है

8

setEscapeButton()

बची हुई कुंजी को दबाने पर बटन को क्लिक के रूप में माना जाता है

उदाहरण

निम्न उदाहरण में, शीर्ष स्तर विंडो पर बटन के संकेत पर क्लिक करें, कनेक्टेड फ़ंक्शन संदेश बॉक्स संवाद प्रदर्शित करता है।

msg = QMessageBox()
msg.setIcon(QMessageBox.Information)
msg.setText("This is a message box")
msg.setInformativeText("This is additional information")
msg.setWindowTitle("MessageBox demo")
msg.setDetailedText("The details are as follows:")

setStandardButton () फ़ंक्शन वांछित बटन प्रदर्शित करता है।

msg.setStandardButtons(QMessageBox.Ok | QMessageBox.Cancel)

बटन क्लच () सिग्नल एक स्लॉट फ़ंक्शन से जुड़ा होता है, जो सिग्नल के स्रोत के कैप्शन की पहचान करता है।

msg.buttonClicked.connect(msgbtn)

उदाहरण के लिए पूरा कोड इस प्रकार है -

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

def window():
   app = QApplication(sys.argv)
   w = QWidget()
   b = QPushButton(w)
   b.setText("Show message!")
   
   b.move(100,50)
   b.clicked.connect(showdialog)
   w.setWindowTitle("PyQt MessageBox demo")
   w.show()
   sys.exit(app.exec_())

def showdialog():
   msg = QMessageBox()
   msg.setIcon(QMessageBox.Information)
   
   msg.setText("This is a message box")
   msg.setInformativeText("This is additional information")
   msg.setWindowTitle("MessageBox demo")
   msg.setDetailedText("The details are as follows:")
   msg.setStandardButtons(QMessageBox.Ok | QMessageBox.Cancel)
   msg.buttonClicked.connect(msgbtn)

   retval = msg.exec_()

def msgbtn(i):
   print ("Button pressed is:",i.text())

if __name__ == '__main__':
   window()

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है। जब मुख्य विंडो का बटन क्लिक किया जाता है तो संदेश बॉक्स पॉप-अप हो जाता है -

यदि आप MessageBox पर Ok या Cancel बटन पर क्लिक करते हैं, तो कंसोल पर निम्न आउटपुट का उत्पादन होता है -

Button pressed is: OK
Button pressed is: Cancel

एक सामान्य GUI एप्लिकेशन में कई विंडो हो सकती हैं। टैब्ड और स्टैक्ड विजेट एक बार में एक ऐसी विंडो को सक्रिय करने की अनुमति देते हैं। हालाँकि, कई बार यह दृष्टिकोण उपयोगी नहीं हो सकता है क्योंकि अन्य विंडो छिपी हुई है।

एक साथ कई विंडो प्रदर्शित करने का एक तरीका उन्हें स्वतंत्र विंडो के रूप में बनाना है। इसे एसडीआई कहा जाता है(single Document Interface)। इसके लिए अधिक मेमोरी संसाधनों की आवश्यकता होती है क्योंकि प्रत्येक विंडो का अपना मेनू सिस्टम, टूलबार आदि हो सकता है।

एमडीआई (Multiple Document Interface)अनुप्रयोग कम मेमोरी संसाधनों का उपभोग करते हैं। उप खिड़कियां मुख्य कंटेनर के अंदर एक दूसरे के संबंध में रखी गई हैं। कंटेनर विजेट कहा जाता हैQMdiArea

QMdiArea विजेट आम तौर पर QMainWondow ऑब्जेक्ट के केंद्रीय विजेट पर है। इस क्षेत्र में बाल खिड़कियां उदाहरण हैंQMdiSubWindowकक्षा। सबविंडो ऑब्जेक्ट के आंतरिक विजेट के रूप में किसी भी QWidget को सेट करना संभव है। एमडीआई क्षेत्र में उप-खिड़कियां कैस्केड या टाइल फैशन में व्यवस्थित की जा सकती हैं।

निम्न तालिका QMdiArea वर्ग और QMdiSubWindow वर्ग के महत्वपूर्ण तरीकों को सूचीबद्ध करती है -

अनु क्रमांक। तरीके और विवरण
1

addSubWindow()

MDI क्षेत्र में एक नए सबविंडो के रूप में एक विजेट जोड़ता है

2

removeSubWindow()

एक विजेट को हटाता है जो एक सबविंडो का आंतरिक विजेट है

3

setActiveSubWindow()

एक सबविंडो सक्रिय करता है

4

cascadeSubWindows()

एक cascaded फैशन में MDiArea में उप-विंडो की व्यवस्था करता है

5

tileSubWindows()

MDIArea में टाइल वाले अंदाज़ में सब-विंडो की व्यवस्था करता है

6

closeActiveSubWindow()

सक्रिय सबविंडो को बंद कर देता है

7

subWindowList()

एमडीआई क्षेत्र में उप-विंडो की सूची लौटाता है

8

setWidget()

QMdiSubwindow उदाहरण के आंतरिक विजेट के रूप में एक QWidget सेट करता है

QMdiArea ऑब्जेक्ट subWindowActivated () सिग्नल का उत्सर्जन करता है जबकि WindowMateChanged () सिग्नल QMdisubWindow ऑब्जेक्ट द्वारा उत्सर्जित होता है।

उदाहरण

निम्नलिखित उदाहरण में, QMainWindow के शीर्ष स्तर की विंडो में एक मेनू और MdiArea है।

self.mdi = QMdiArea()
self.setCentralWidget(self.mdi)
bar = self.menuBar()
file = bar.addMenu("File")

file.addAction("New")
file.addAction("cascade")
file.addAction("Tiled")

मेनू का ट्रिगर () संकेत विंडोनेशन () फ़ंक्शन से जुड़ा है।

file.triggered[QAction].connect(self.windowaction)

मेनू की नई क्रिया एमडीआई क्षेत्र में एक उप-घटाव को जोड़ती है जिसमें एक शीर्षक होता है जिसमें एक वृद्धिशील संख्या होती है।

MainWindow.count = MainWindow.count+1
sub = QMdiSubWindow()
sub.setWidget(QTextEdit())
sub.setWindowTitle("subwindow"+str(MainWindow.count))
self.mdi.addSubWindow(sub)
sub.show()

मेनू के कैस्केड और टाइल वाले बटन वर्तमान में क्रमशः कैस्केड और टाइल वाले फैशन में उप-विंडो प्रदर्शित करते हैं।

पूरा कोड इस प्रकार है -

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

class MainWindow(QMainWindow):
   count = 0

   def __init__(self, parent = None):
      super(MainWindow, self).__init__(parent)
      self.mdi = QMdiArea()
      self.setCentralWidget(self.mdi)
      bar = self.menuBar()

      file = bar.addMenu("File")
      file.addAction("New")
      file.addAction("cascade")
      file.addAction("Tiled")
      file.triggered[QAction].connect(self.windowaction)
      self.setWindowTitle("MDI demo")

   def windowaction(self, q):
      print ("triggered")
   
      if q.text() == "New":
         MainWindow.count = MainWindow.count+1
         sub = QMdiSubWindow()
         sub.setWidget(QTextEdit())
         sub.setWindowTitle("subwindow"+str(MainWindow.count))
         self.mdi.addSubWindow(sub)
         sub.show()

      if q.text() == "cascade":
         self.mdi.cascadeSubWindows()

      if q.text() == "Tiled":
         self.mdi.tileSubWindows()

def main():
   app = QApplication(sys.argv)
   ex = MainWindow()
   ex.show()
   sys.exit(app.exec_())

if __name__ == '__main__':
   main()

कोड और तीन खिड़कियों के ऊपर कैस्केड और टाइल वाले गठन में चलाएं -

का प्रावधान drag and dropउपयोगकर्ता के लिए बहुत सहज है। यह कई डेस्कटॉप अनुप्रयोगों में पाया जाता है जहां उपयोगकर्ता एक विंडो से दूसरी विंडो में ऑब्जेक्ट को कॉपी या स्थानांतरित कर सकता है।

MIME आधारित ड्रैग एंड ड्रॉप डेटा ट्रांसफर पर आधारित है QDrag कक्षा। QMimeDataऑब्जेक्ट डेटा को उनके संबंधित MIME प्रकार के साथ जोड़ते हैं। इसे क्लिपबोर्ड पर संग्रहीत किया जाता है और फिर ड्रैग एंड ड्रॉप प्रक्रिया में उपयोग किया जाता है।

निम्न QMimeData वर्ग फ़ंक्शन MIME प्रकार का पता लगाने और आसानी से उपयोग करने की अनुमति देते हैं।

टेस्टर प्राप्त करनेवाला बैठानेवाला MIME प्रकार
hasText () पाठ () setText () पाठ / सादे
hasHtml () एचटीएमएल () setHtml () पाठ / html
hasUrls () यूआरएल () setUrls () पाठ / uri-सूची
hasImage () imageData () setImageData () छवि / *
hasColor () colorData () setColorData () आवेदन / x-रंग

कई QWidget ऑब्जेक्ट ड्रैग और ड्रॉप गतिविधि का समर्थन करते हैं। जो अपने डेटा को खींचने की अनुमति देते हैं, उनमें सेटट्राएंगेबल () होता है जिसे सही पर सेट किया जाना चाहिए। दूसरी ओर, विगेट्स को ड्रैग और ड्रॉप ईवेंट का जवाब देना चाहिए ताकि उनमें खींचे गए डेटा को स्टोर किया जा सके।

  • DragEnterEvent एक ईवेंट प्रदान करता है, जो लक्ष्य विजेट को भेजा जाता है क्योंकि खींचने वाली क्रिया इसमें प्रवेश करती है।

  • DragMoveEvent का उपयोग तब किया जाता है जब ड्रैग एंड ड्रॉप की कार्रवाई जारी रहती है।

  • DragLeaveEvent विजेट को छोड़ने और छोड़ने की क्रिया के रूप में उत्पन्न होता है।

  • DropEventदूसरी ओर, तब होता है जब ड्रॉप पूरा हो जाता है। घटना की प्रस्तावित कार्रवाई को सशर्त स्वीकार या अस्वीकार किया जा सकता है।

उदाहरण

निम्नलिखित कोड में, DragEnterEventयह सत्यापित करता है कि इवेंट के MIME डेटा में टेक्स्ट है या नहीं। यदि हाँ, तो ईवेंट की प्रस्तावित कार्रवाई स्वीकार कर ली जाती है और कॉम्बो बॉक्स में टेक्स्ट को एक नए आइटम के रूप में जोड़ दिया जाता है।

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

class combo(QComboBox):
   def __init__(self, title, parent):
      super(combo, self).__init__( parent)
      self.setAcceptDrops(True)

   def dragEnterEvent(self, e):
      print (e)

      if e.mimeData().hasText():
         e.accept()
      else:
         e.ignore()

   def dropEvent(self, e):
      self.addItem(e.mimeData().text())

class Example(QWidget):
   def __init__(self):
      super(Example, self).__init__()

      self.initUI()

   def initUI(self):
      lo = QFormLayout()
      lo.addRow(QLabel("Type some text in textbox and drag it into combo box"))
   
      edit = QLineEdit()
      edit.setDragEnabled(True)
      com = combo("Button", self)
      lo.addRow(edit,com)
      self.setLayout(lo)
      self.setWindowTitle('Simple drag and drop')
def main():
   app = QApplication(sys.argv)
   ex = Example()
   ex.show()
   app.exec_()

if __name__ == '__main__':
   main()

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

PyQt5 लाइब्रेरी में है QtSqlमापांक। यह कई एसक्यूएल आधारित डेटाबेस के साथ संवाद करने के लिए एक विस्तृत वर्ग प्रणाली है। आईटी इसQSqlDatabaseएक कनेक्शन वस्तु के माध्यम से पहुँच प्रदान करता है। निम्नलिखित वर्तमान में उपलब्ध SQL ड्राइवरों की सूची है -

अनु क्रमांक। ड्राइवर का प्रकार और विवरण
1

QDB2

आईबीएम DB2

2

QIBASE

बोरलैंड इंटरबेस ड्राइवर

3

QMYSQL

MySQL ड्राइवर

4

QOCI

ओरेकल कॉल इंटरफ़ेस ड्राइवर

5

QODBC

ODBC ड्राइवर (Microsoft SQL सर्वर शामिल है)

6

QPSQL

PostgreSQL ड्राइवर

7

QSQLITE

SQLite संस्करण 3 या उससे ऊपर

8

QSQLITE2

SQLite संस्करण 2

उदाहरण

इस अध्याय के लिए, SQLite डेटाबेस के साथ एक कनेक्शन स्थैतिक विधि का उपयोग करके स्थापित किया गया है -

db = QtSql.QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sports.db')

QSqlDatabase class के अन्य तरीके इस प्रकार हैं -

अनु क्रमांक। तरीके और विवरण
1

setDatabaseName()

उस डेटाबेस का नाम सेट करता है जिसके साथ कनेक्शन मांगा गया है

2

setHostName()

उस होस्ट का नाम सेट करता है जिस पर डेटाबेस स्थापित है

3

setUserName()

कनेक्शन के लिए उपयोगकर्ता नाम निर्दिष्ट करता है

4

setPassword()

यदि कोई हो तो कनेक्शन ऑब्जेक्ट का पासवर्ड सेट करता है

5

commit()

लेनदेन को पूरा करता है और सफल होने पर सही रिटर्न देता है

6

rollback()

डेटाबेस लेनदेन को वापस रोल करता है

7

close()

कनेक्शन बंद कर देता है

QSqlQueryक्लास में SQL कमांड को निष्पादित और हेरफेर करने की कार्यक्षमता है। डीडीएल और डीएमएल दोनों प्रकार के एसक्यूएल प्रश्नों को निष्पादित किया जा सकता है। पहला कदम निम्नलिखित बयानों का उपयोग करके SQlite डेटाबेस बनाना है -

db = QSqlDatabase.addDatabase('QSQLITE')
db.setDatabaseName('sportsdatabase.db')

इसके बाद, क्वेरी ऑब्जेक्ट को प्राप्त करें QSqlQuery() पद्धति और इसके सबसे महत्वपूर्ण तरीके को exec_ () कहते हैं, जो कि एक तर्क के रूप में लिया जाता है जिसमें SQL कथन को निष्पादित किया जाता है।

query = QtSql.QSqlQuery()
query.exec_("create table sportsmen(id int primary key, " "firstname varchar(20), lastname varchar(20))")

निम्न स्क्रिप्ट पाँच रिकॉर्ड के साथ आबादी वाले स्पोर्ट्सपर्सन की तालिका के साथ SQLite डेटाबेस sports.db बनाता है।

import sys
from PyQt5.QtSql import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

def createDB():
   db = QSqlDatabase.addDatabase('QSQLITE')
   db.setDatabaseName('sportsdatabase.db')

   if not db.open():
      msg = QMessageBox()
      msg.setIcon(QMessageBox.Critical)
      msg.setText("Error in Database Creation")
      retval = msg.exec_()
      return False
   query = QSqlQuery()

   query.exec_("create table sportsmen(
      id int primary key, ""firstname varchar(20), lastname varchar(20))")

   query.exec_("insert into sportsmen values(101, 'Roger', 'Federer')")
   query.exec_("insert into sportsmen values(102, 'Christiano', 'Ronaldo')")
   query.exec_("insert into sportsmen values(103, 'Ussain', 'Bolt')")
   query.exec_("insert into sportsmen values(104, 'Sachin', 'Tendulkar')")
   query.exec_("insert into sportsmen values(105, 'Saina', 'Nehwal')")
   return True

if __name__ == '__main__':
   app = QApplication(sys.argv)
   createDB()

यह पुष्टि करने के लिए कि इसमें स्पोर्ट्समैन तालिका में जोड़े गए उपरोक्त रिकॉर्ड के साथ SQLite डेटाबेस बनाया गया है, नामक SQLite Gui उपयोगिता का उपयोग करें SQLiteStudio

QSqlTableModelPyQt में कक्षा एक उच्च-स्तरीय इंटरफ़ेस है जो एकल तालिका में रिकॉर्ड पढ़ने और लिखने के लिए संपादन योग्य डेटा मॉडल प्रदान करता है। इस मॉडल का उपयोग पॉप्युलेट करने के लिए किया जाता हैQTableViewवस्तु। यह उपयोगकर्ता को एक स्क्रॉल करने योग्य और संपादन योग्य दृश्य प्रस्तुत करता है जिसे किसी भी शीर्ष स्तर की खिड़की पर रखा जा सकता है।

एक QSqlTableModel ऑब्जेक्ट को निम्न तरीके से घोषित किया जाता है -

model = QtSql.QSqlTableModel()

इसकी संपादन रणनीति निम्नलिखित में से किसी में भी सेट की जा सकती है -

QSqlTableModel.OnFieldChange सभी परिवर्तनों को तुरंत लागू किया जाएगा
QSqlTableModel.OnRowChange जब उपयोगकर्ता एक अलग पंक्ति का चयन करता है तो परिवर्तन लागू किए जाएंगे
QSqlTableModel.OnManualSubmit सभी परिवर्तनों को तब तक कैश किया जाएगा जब तक कि सब सबमिट नहीं करेंगे () या रिवर्ट () को कहा जाता है

उदाहरण

निम्नलिखित उदाहरण में, स्पोर्ट्सपर्सन टेबल का उपयोग एक मॉडल के रूप में किया जाता है और रणनीति निम्नानुसार सेट की जाती है -

model.setTable('sportsmen') 
model.setEditStrategy(QtSql.QSqlTableModel.OnFieldChange)
   model.select()

क्यूटेबल व्यू वर्ग PyQt में मॉडल / व्यू फ्रेमवर्क का हिस्सा है। QTableView ऑब्जेक्ट निम्नानुसार बनाया गया है -

view = QtGui.QTableView()
view.setModel(model)
view.setWindowTitle(title)
return view

यह qableableView ऑब्जेक्ट और दो QPushButton विजेट्स शीर्ष स्तर QDialog विंडो में जोड़े जाते हैं। ऐड बटन पर क्लिक () सिग्नल एड्रो से जुड़ा हुआ है () जो मॉडल टेबल पर इन्सर्ट रो () करता है।

button.clicked.connect(addrow)
def addrow():
   print model.rowCount()
   ret = model.insertRows(model.rowCount(), 1)
   print ret

डिलीट बटन से जुड़ा स्लॉट एक लैंबडा फ़ंक्शन को निष्पादित करता है जो एक पंक्ति को हटाता है, जिसे उपयोगकर्ता द्वारा चुना जाता है।

btn1.clicked.connect(lambda: model.removeRow(view1.currentIndex().row()))

पूरा कोड इस प्रकार है -

import sys
from PyQt5.QtSql import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

def initializeModel(model):
   model.setTable('sportsmen')
   model.setEditStrategy(QSqlTableModel.OnFieldChange)
   model.select()
   model.setHeaderData(0, Qt.Horizontal, "ID")
   model.setHeaderData(1, Qt.Horizontal, "First name")
   model.setHeaderData(2, Qt.Horizontal, "Last name")

def createView(title, model):
   view = QTableView()
   view.setModel(model)
   view.setWindowTitle(title)
   return view

def addrow():
   print (model.rowCount())
   ret = model.insertRows(model.rowCount(), 1)
   print (ret)

def findrow(i):
   delrow = i.row()

if __name__ == '__main__':
   app = QApplication(sys.argv)
   db = QSqlDatabase.addDatabase('QSQLITE')
   db.setDatabaseName('sportsdatabase.db')
   model = QSqlTableModel()
   delrow = -1
   initializeModel(model)

   view1 = createView("Table Model (View 1)", model)
   view1.clicked.connect(findrow)

   dlg = QDialog()
   layout = QVBoxLayout()
   layout.addWidget(view1)

   button = QPushButton("Add a row")
   button.clicked.connect(addrow)
   layout.addWidget(button)

   btn1 = QPushButton("del a row")
   btn1.clicked.connect(lambda: model.removeRow(view1.currentIndex().row()))
   layout.addWidget(btn1)

   dlg.setLayout(layout)
   dlg.setWindowTitle("Database Demo")
   dlg.show()
   sys.exit(app.exec_())

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

कुछ रिकॉर्ड जोड़ने और हटाने का प्रयास करें और लेनदेन की पुष्टि करने के लिए SQLiteStudio पर वापस जाएं।

सब QWidgetPyQt में कक्षाएं QPaintDevice वर्ग से उप-वर्गित हैं। एQPaintDeviceएक दो आयामी स्थान है जो एक QPainter का उपयोग करने पर खींचा जा सकता है। पेंट डिवाइस के आयामों को शीर्ष-बाएं कोने से शुरू होने वाले पिक्सेल में मापा जाता है।

QPainterकक्षा विजेट और प्रिंटर जैसे अन्य पेंट करने योग्य उपकरणों पर निम्न स्तर की पेंटिंग करती है। आम तौर पर, विजेट के पेंट इवेंट में इसका उपयोग किया जाता है। QPaintEvent जब भी विजेट का स्वरूप अद्यतन किया जाता है।

चित्रकार को कॉल करके सक्रिय किया जाता है begin() विधि, जबकि end()विधि इसे निष्क्रिय कर देती है। बीच में, वांछित पैटर्न उपयुक्त विधियों द्वारा चित्रित किया गया है जैसा कि निम्न तालिका में सूचीबद्ध है।

अनु क्रमांक। तरीके और विवरण
1

begin()

लक्ष्य डिवाइस पर पेंटिंग शुरू करता है

2

drawArc()

शुरू और अंत कोण के बीच एक चाप खींचता है

3

drawEllipse()

एक आयत के अंदर एक दीर्घवृत्त खींचता है

4

drawLine()

निर्दिष्ट बिंदु निर्देशांक के साथ एक रेखा खींचता है

5

drawPixmap()

पिक्समैप को छवि फ़ाइल से निकालता है और इसे निर्दिष्ट स्थान पर प्रदर्शित करता है

6

drwaPolygon()

निर्देशांक की एक सरणी का उपयोग कर एक बहुभुज खींचता है

7

drawRect()

दी गई चौड़ाई और ऊंचाई के साथ ऊपरी-बाएँ समन्वय पर शुरू होने वाली एक आयत खींचता है

8

drawText()

दिए गए निर्देशांक पर पाठ प्रदर्शित करता है

9

fillRect()

क्यूक्लर पैरामीटर के साथ आयत को भरता है

10

setBrush()

पेंटिंग के लिए एक ब्रश शैली सेट करता है

1 1

setPen()

ड्राइंग के लिए उपयोग किए जाने वाले पेन का रंग, आकार और शैली सेट करता है

उदाहरण

निम्नलिखित कोड में, PyQt की ड्राइंग विधियों के विभिन्न तरीकों का उपयोग किया जाता है।

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

class Example(QWidget):
   def __init__(self):
      super(Example, self).__init__()
      self.initUI()

   def initUI(self):
      self.text = "hello world"
      self.setGeometry(100,100, 400,300)
      self.setWindowTitle('Draw Demo')
      self.show()

   def paintEvent(self, event):
      qp = QPainter()
      qp.begin(self)
      qp.setPen(QColor(Qt.red))
      qp.setFont(QFont('Arial', 20))
      qp.drawText(10,50, "hello Python")
      qp.setPen(QColor(Qt.blue))
      qp.drawLine(10,100,100,100)
      qp.drawRect(10,150,150,100)
      qp.setPen(QColor(Qt.yellow))
      qp.drawEllipse(100,50,100,50)
      qp.drawPixmap(220,10,QPixmap("pythonlogo.png"))
      qp.fillRect(20,175,130,70,QBrush(Qt.SolidPattern))
      qp.end()

def main():
   app = QApplication(sys.argv)
   ex = Example()
   sys.exit(app.exec_())

if __name__ == '__main__':
   main()

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

इस अध्याय में, हम ब्रश स्टाइल कॉन्स्टेंट सीखेंगे।

ब्रश स्टाइल कांस्टेंट

नीचे दिए गए ब्रश स्टाइल कॉन्स्टेंट हैं -

Qt.NoBrush कोई ब्रश पैटर्न नहीं
Qt.SolidPattern वर्दी का रंग
Qt.Dense1Pattern बेहद घने ब्रश पैटर्न
Qt.HorPattern क्षैतिज रेखाएँ
Qt.VerPattern ऊर्ध्वाधर पंक्तियां
Qt.CrossPattern क्षैतिज और ऊर्ध्वाधर लाइनों को पार करना
Qt.BDiagPattern पिछड़ी हुई विकर्ण रेखाएँ
Qt.FDiagPattern आगे तिरछी रेखाएँ
Qt.DiagCrossPattern विकर्ण रेखाओं को पार करना

पूर्वनिर्धारित QColor शैलियाँ

नीचे दिए गए पूर्वनिर्धारित QColor शैलियाँ हैं -

Qt.NoBrush कोई ब्रश पैटर्न नहीं
Qt.SolidPattern वर्दी का रंग
Qt.Dense1Pattern बेहद घने ब्रश पैटर्न
Qt.HorPattern क्षैतिज रेखाएँ
Qt.VerPattern ऊर्ध्वाधर पंक्तियां
Qt.CrossPattern क्षैतिज और ऊर्ध्वाधर लाइनों को पार करना
Qt.BDiagPattern पिछड़ी हुई विकर्ण रेखाएँ
Qt.FDiagPattern आगे तिरछी रेखाएँ
Qt.DiagCrossPattern विकर्ण रेखाओं को पार करना

पूर्वनिर्धारित QColor वस्तुओं

नीचे दिए गए पूर्वनिर्धारित QColor वस्तुएँ हैं -

Qt.white
Qt.black
Qt.red
Qt.darkRed
Qt.green
Qt.darkGreen
Qt.blue
Qt.cyan
Qt.magenta
Qt.yellow
Qt.darkYellow
Qt.gray

QClipboardक्लास सिस्टम-वाइड क्लिपबोर्ड तक पहुंच प्रदान करता है जो अनुप्रयोगों के बीच डेटा को कॉपी और पेस्ट करने के लिए एक सरल तंत्र प्रदान करता है। इसकी क्रिया भी इसके समान हैQDrag वर्ग और समान डेटा प्रकार का उपयोग करता है।

QApplication class में एक static method है clipboard()जो क्लिपबोर्ड ऑब्जेक्ट का संदर्भ देता है। किसी भी प्रकार के MimeData को क्लिपबोर्ड से कॉपी या पेस्ट किया जा सकता है।

निम्नलिखित क्लिपबोर्ड वर्ग विधियां हैं जो आमतौर पर उपयोग की जाती हैं -

अनु क्रमांक। तरीके और विवरण
1

clear()

क्लिपबोर्ड सामग्री साफ़ करता है

2

setImage()

क्लिपबोर्ड में QImage की प्रतियां

3

setMimeData()

MIME डेटा को क्लिपबोर्ड में सेट करता है

4

setPixmap()

क्लिपबोर्ड में कॉपी पिक्समैप ऑब्जेक्ट

5

setText()

क्लिपबोर्ड में प्रतियां QString

6

text()

क्लिपबोर्ड से पाठ को पुनः प्राप्त करता है

क्लिपबोर्ड ऑब्जेक्ट से जुड़ा सिग्नल है -

अनु क्रमांक। विधि और विवरण
1

dataChanged()

जब भी क्लिपबोर्ड डेटा बदलता है

उदाहरण

निम्न उदाहरण में, दो TextEdit ऑब्जेक्ट और दो Pushbuttons एक शीर्ष स्तर विंडो में जोड़े जाते हैं।

क्लिपबोर्ड ऑब्जेक्ट के साथ शुरू करने के लिए त्वरित है। Textedit ऑब्जेक्ट की कॉपी () विधि डेटा को सिस्टम क्लिपबोर्ड पर कॉपी करती है। जब पेस्ट बटन पर क्लिक किया जाता है, तो यह क्लिपबोर्ड डेटा प्राप्त करता है और इसे अन्य टेक्स्टडिट ऑब्जेक्ट में पेस्ट करता है।

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

class Example(QWidget):
   def __init__(self):
      super(Example, self).__init__()

      self.initUI()

   def initUI(self):
      hbox = QVBoxLayout()
      self.edit1=QTextEdit()
      hbox.addWidget(self.edit1)
      self.btn1=QPushButton("Copy")
      hbox.addWidget(self.btn1)
      self.edit2=QTextEdit()
      self.btn2=QPushButton("Paste")
      hbox.addWidget(self.edit2)
      hbox.addWidget(self.btn2)
      self.btn1.clicked.connect(self.copytext)
      self.btn2.clicked.connect(self.pastetext)
      self.setLayout(hbox)
      
      self.setGeometry(300, 300, 300, 200)
      self.setWindowTitle('Clipboard')
      self.show()
      
   def copytext(self):

      #clipboard.setText(self.edit1.copy())
      self.edit1.copy()
      print (clipboard.text())

      msg=QMessageBox()
      msg.setText(clipboard.text()+" copied on clipboard")
      msg.exec_()

   def pastetext(self):
      self.edit2.setText(clipboard.text())

app = QApplication(sys.argv)
clipboard=app.clipboard()
ex = Example()
ex.setWindowTitle("clipboard Example")
sys.exit(app.exec_())

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -

QPixmapवर्ग एक छवि का ऑफ-स्क्रीन प्रतिनिधित्व प्रदान करता है। इसका उपयोग QPaintDevice ऑब्जेक्ट के रूप में किया जा सकता है या किसी अन्य विजेट में लोड किया जा सकता है, आमतौर पर एक लेबल या बटन।

Qt API में एक और समान वर्ग है QImage, जो I / O और अन्य पिक्सेल जोड़तोड़ के लिए अनुकूलित है। दूसरी ओर, Pixmap स्क्रीन पर इसे दिखाने के लिए अनुकूलित है। दोनों प्रारूप आपस में जुड़े हुए हैं।

इमेज फाइल के प्रकार जिन्हें QPixmap ऑब्जेक्ट में पढ़ा जा सकता है वे इस प्रकार हैं -

बीएमपी विंडोज बिटमैप
GIF ग्राफिक इंटरचेंज प्रारूप (वैकल्पिक)
जेपीजी फ़ोटोग्राफ़ी संबंधी विशेषज्ञों का संयुक्त समूह
जेपीईजी फ़ोटोग्राफ़ी संबंधी विशेषज्ञों का संयुक्त समूह
पीएनजी पोर्टेबल नेटवर्क ग्राफ़िक्स
पीबीएम पोर्टेबल बिटमैप
PGM पोर्टेबल ग्रेमैप
पीपीएम पोर्टेबल पिक्समैप
XBM X11 बिटमैप
XPM X11 पिक्समैप

QPixmap ऑब्जेक्ट को संभालने में निम्नलिखित तरीके उपयोगी हैं -

अनु क्रमांक। तरीके और विवरण
1

copy()

पिक्समैप डेटा को एक क्यूरेक्ट ऑब्जेक्ट से कॉपी करता है

2

fromImage()

QPmmap में QImage ऑब्जेक्ट को कनवर्ट करता है

3

grabWidget()

दिए गए विजेट से एक पिक्समैप बनाता है

4

grabWindow()

एक विंडो में डेटा का Pixmap बनाएं

5

Load()

पिक्समैप के रूप में एक छवि फ़ाइल लोड करता है

6

save()

QPixmap ऑब्जेक्ट को फ़ाइल के रूप में सहेजता है

7

toImage

एक QPixmap को QImage में रूपांतरित करता है

QPixmap का सबसे आम उपयोग लेबल / बटन पर चित्र प्रदर्शित करना है।

उदाहरण

निम्न उदाहरण QLabel पर प्रदर्शित चित्र को दिखाता है setPixmap() तरीका।

पूरा कोड इस प्रकार है -

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

def window():
   app = QApplication(sys.argv)
   win = QWidget()
   l1 = QLabel()
   l1.setPixmap(QPixmap("python.png"))

   vbox = QVBoxLayout()
   vbox.addWidget(l1)
   win.setLayout(vbox)
   win.setWindowTitle("QPixmap Demo")
   win.show()
   sys.exit(app.exec_())

if __name__ == '__main__':
   window()

उपरोक्त कोड निम्नलिखित आउटपुट का उत्पादन करता है -