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

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

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

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

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

खिड़कियाँ

आप पायथन संस्करण (2.7 या 3.4) और हार्डवेयर आर्किटेक्चर (32 बिट या 64 बिट) के अनुरूप उपरोक्त डाउनलोड लिंक से एक उपयुक्त इंस्टॉलर डाउनलोड और स्थापित कर सकते हैं। ध्यान दें कि PyQt के दो संस्करण हैं जो क्रमशः उपलब्ध हैं,PyQt 4.8 तथा PyQt 5.5

जबकि PyQt4 Python 2 के साथ-साथ Python 3 के लिए भी उपलब्ध है, PyQt5 का उपयोग Python 3. * के साथ ही किया जा सकता है।

PyQt4 Windows Binaries

PyQt4-4.11.4-जीपीएल-Py3.4-Qt4.8.7-x64.exe विंडोज 64 बिट इंस्टॉलर
PyQt4-4.11.4-जीपीएल-Py3.4-Qt4.8.7-x32.exe विंडोज 32 बिट इंस्टॉलर
PyQt4-4.11.4-जीपीएल-Py3.4-Qt5.5.0-x64.exe विंडोज 64 बिट इंस्टॉलर
PyQt4-4.11.4-जीपीएल-Py3.4-Qt5.5.0-x32.exe विंडोज 32 बिट इंस्टॉलर
PyQt4-4.11.4-जीपीएल-Py2.7-Qt4.8.7-x64.exe विंडोज 64 बिट इंस्टॉलर
PyQt4-4.11.4-जीपीएल-Py2.7-Qt4.8.7-x32.exe विंडोज 32 बिट इंस्टॉलर

PyQt5 Windows Binaries

PyQt5-5.5-जीपीएल-Py3.4-Qt5.5.0-x64.exe विंडोज 64 बिट इंस्टॉलर
PyQt5-5.5-जीपीएल-Py3.4-Qt5.5.0-x32.exe विंडोज 32 बिट इंस्टॉलर

लिनक्स

Ubuntu या किसी अन्य डेबियन लिनक्स वितरण के लिए, PyQt को स्थापित करने के लिए निम्नलिखित कमांड का उपयोग करें -

sudo apt-get install python-qt4
or 
sudo apt-get install pyqt5-dev-tools

आप 'डाउनलोड' पृष्ठ पर उपलब्ध स्रोत कोड से भी निर्माण कर सकते हैं।

PyQt-X11-जीपीएल-4.11.4.tar.gz लिनक्स, PyQt4 के लिए UNIX स्रोत
PyQt-जीपीएल-5.5.tar.gz PyQt5 के लिए लिनक्स, UNIX, MacOS / X स्रोत

मैक ओ एस

PyQtX परियोजना (http://sourceforge.net/projects/pyqtx/) मैक के लिए PyQt के बायनेरिज़ होस्ट करता है। होमब्रेव इंस्टॉलर का प्रयोग निम्न कमांड के अनुसार करें -

brew install pyqt

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

  • आयात QtGui मॉड्यूल।

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

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

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

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

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

import sys
from PyQt4 import QtGui

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

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

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

QtAssistant

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

12

QtDesigner

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

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 डिज़ाइनर के पास एप्लिकेशन को डीबग करने और बनाने की सुविधा नहीं है।

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

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

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

pyuic4 –x demo.ui –o demo.py

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

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_())

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

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

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

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

PyQt में, एक संकेत और एक स्लॉट के बीच संबंध विभिन्न तरीकों से हासिल किया जा सकता है। सबसे अधिक इस्तेमाल की जाने वाली तकनीकें निम्नलिखित हैं -

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

एक स्लॉट_फंक्शन को कॉल करने का एक और अधिक सुविधाजनक तरीका, जब एक विजेट द्वारा सिग्नल उत्सर्जित किया जाता है, इस प्रकार है -

widget.signal.connect(slot_function)

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

QtCore.QObject.connect(button, QtCore.SIGNAL(“clicked()”), 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 () फ़ंक्शन से जुड़ा होता है

QObject.connect(b2, SIGNAL("clicked()"), b2_clicked)

उदाहरण

import sys
from PyQt4.QtCore import *
from PyQt4.QtGui 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)
   QObject.connect(b2,SIGNAL("clicked()"),b2_clicked)

   win.setGeometry(100,100,200,100)
   win.setWindowTitle("PyQt")
   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 पिक्सेल नीचे।

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

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

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

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

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

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

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

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

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

अनु क्रमांक। कक्षाएं और विवरण
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

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

17 QDock

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

18 QStatusBar

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

19 QList

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

20 QScrollBar

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

21 QCalendar

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

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

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

उदाहरण

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

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

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

import sys
from PyQt4.QtGui import *
from PyQt4.QtCore import *

def window():
   app = QApplication(sys.argv)
   w = QWidget()
   b = QPushButton(w)
   b.setText("Hello World!")
   b.move(50,50)
   b.clicked.connect(showdialog)
   w.setWindowTitle("PyQt Dialog demo")
   w.show()
   sys.exit(app.exec_())
	
def showdialog():
   d = QDialog()
   b1 = QPushButton("ok",d)
   b1.move(50,50)
   d.setWindowTitle("Dialog")
   d.setWindowModality(Qt.ApplicationModal)
   d.exec_()
	
if __name__ == '__main__':
   window()

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

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

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

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

setIcon()

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

सवाल

जानकारी

चेतावनी

नाजुक

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 PyQt4.QtGui import *
from PyQt4.QtCore import *

def window():
   app = QApplication(sys.argv)
   w = QWidget()
   b = QPushButton(w)
   b.setText("Show message!")

   b.move(50,50)
   b.clicked.connect(showdialog)
   w.setWindowTitle("PyQt Dialog 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_()
   print "value of pressed message box button:", retval
	
def msgbtn(i):
   print "Button pressed is:",i.text()
	
if __name__ == '__main__': 
   window()

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

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

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

एमडीआई (मल्टीपल डॉक्यूमेंट इंटरफेस) एप्लिकेशन कम मेमोरी संसाधनों का उपभोग करते हैं। उप-खिड़कियां मुख्य कंटेनर के अंदर एक दूसरे के संबंध में रखी गई हैं। कंटेनर विजेट कहा जाता है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 () सिग्नल का उत्सर्जन करता है जबकि WindowStateChanged () सिग्नल 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 PyQt4.QtCore import *
from PyQt4.QtGui 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 PyQt4.QtGui import *
from PyQt4.QtCore 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 & drop')
		
def main():
   app = QApplication(sys.argv)
   ex = Example()
   ex.show()
   app.exec_()
	
if __name__ == '__main__':
   main()

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

PyQt API में कई SQL आधारित डेटाबेस के साथ संचार करने के लिए एक विस्तृत वर्ग प्रणाली है। इसके 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 कमांड को निष्पादित और हेरफेर करने की कार्यक्षमता है। डीडीएल और डीएमएल दोनों प्रकार के एसक्यूएल प्रश्नों को निष्पादित किया जा सकता है। कक्षा में सबसे महत्वपूर्ण तरीका है exec_ (), जो एक तर्क के रूप में लेता है जिसमें SQL स्टेटमेंट को निष्पादित किया जाता है।

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

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

from PyQt4 import QtSql, QtGui

def createDB():
   db = QtSql.QSqlDatabase.addDatabase('QSQLITE')
   db.setDatabaseName('sports.db')
	
   if not db.open():
      QtGui.QMessageBox.critical(None, QtGui.qApp.tr("Cannot open database"),
         QtGui.qApp.tr("Unable to establish a database connection.\n"
            "This example needs SQLite support. Please read "
            "the Qt SQL driver documentation for information "
            "how to build it.\n\n" "Click Cancel to exit."),
         QtGui.QMessageBox.Cancel)
			
      return False
		
   query = QtSql.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__':
   import sys
	
   app = QtGui.QApplication(sys.argv)
   createDB()

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

एक qableableModel वस्तु को निम्नलिखित तरीके से घोषित किया जाता है -

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 PyQt4 import QtCore, QtGui, QtSql
import sportsconnection

def initializeModel(model):
   model.setTable('sportsmen')
   model.setEditStrategy(QtSql.QSqlTableModel.OnFieldChange)
   model.select()
   model.setHeaderData(0, QtCore.Qt.Horizontal, "ID")
   model.setHeaderData(1, QtCore.Qt.Horizontal, "First name")
   model.setHeaderData(2, QtCore.Qt.Horizontal, "Last name")
	
def createView(title, model):
   view = QtGui.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 = QtGui.QApplication(sys.argv)
   db = QtSql.QSqlDatabase.addDatabase('QSQLITE')
   db.setDatabaseName('sports.db')
   model = QtSql.QSqlTableModel()
   delrow = -1
   initializeModel(model)
	
   view1 = createView("Table Model (View 1)", model)
   view1.clicked.connect(findrow)
	
   dlg = QtGui.QDialog()
   layout = QtGui.QVBoxLayout()
   layout.addWidget(view1)
	
   button = QtGui.QPushButton("Add a row")
   button.clicked.connect(addrow)
   layout.addWidget(button)
	
   btn1 = QtGui.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_())

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

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

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

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

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

begin()

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

2

drawArc()

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

3

drawEllipse()

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

4

drawLine()

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

5

drawPixmap()

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

6

drwaPolygon()

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

7

drawRect()

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

8

drawText()

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

9

fillRect()

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

10

setBrush()

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

1 1

setPen()

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

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

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

पूर्वनिर्धारित 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

कस्टम रंग को RGB या CMYK या HSV मान निर्दिष्ट करके चुना जा सकता है।

उदाहरण

निम्न उदाहरण इन विधियों में से कुछ को लागू करता है।

import sys
from PyQt4.QtGui import *
from PyQt4.QtCore 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 Pyth
		on")
      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("python.jpg"))
      qp.fillRect(200,175,150,100,QBrush(Qt.SolidPattern))
      qp.end()
		
def main():
   app = QApplication(sys.argv)
   ex = Example()
   sys.exit(app.exec_())
	
if __name__ == '__main__':
   main()

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

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

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

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

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

clear()

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

2

setImage()

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

3

setMimeData()

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

4

setPixmap()

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

5

setText()

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

6

text()

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

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

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

dataChanged()

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

उदाहरण

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

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

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 पर प्रदर्शित छवि दिखाता है। पूरा कोड इस प्रकार है -

import sys
from PyQt4.QtCore import *
from PyQt4.QtGui import *

def window():
   app = QApplication(sys.argv)
   win = QWidget()
   l1 = QLabel()
   l1.setPixmap(QPixmap("python.jpg"))
	
   vbox = QVBoxLayout()
   vbox.addWidget(l1)
   win.setLayout(vbox)
   win.setWindowTitle("QPixmap Demo")
   win.show()
   sys.exit(app.exec_())
	
if __name__ == '__main__':
   window()

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