如何从PyQt4中的QTextEdit获取输入

时间:2017-09-14 04:42:40

标签: python python-2.7 pyqt pyqt4 pyqt5

如何解决以下问题 我无法从QTextEdit获取文本并将其插入数据库...

代码:

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

e1=None
e2=None

def window():
    app=QApplication(sys.argv)
    win=QWidget()
    win.setWindowTitle("Sample")
    vbox=QVBoxLayout()
    e1 = QTextEdit()
    e2 = QTextEdit()
    vbox.addWidget(e1)
    vbox.addWidget(e2)
    vbox.addStretch()
    b1=QPushButton("Tap it!")
    vbox.addWidget(b1)
    b1.clicked.connect(b1_action)
    win.setGeometry(100,100,200,50)
    win.setLayout(vbox)
    win.show()
    sys.exit(app.exec_())

def b1_action():
    print "Button Clicked"
    db = MySQLdb.connect('localhost', 'root', 'mysql', 'Tecoc354')
    cursor=db.cursor()
    x1=e1.toPlainText()
    x2=e2.toPlainText()
    print x1," ",x2," "
    #sql="create table Sample(addr varchar(10),name varchar(10))"
   # cursor.execute(sql)
    sql2="insert into Tecoc354.sample values(%s,%s)"%(x1,x2)
    cursor.execute(sql2)
    db.commit()
    db.close()

window()

1 个答案:

答案 0 :(得分:0)

这里的问题是,在b1_action()中,变量e1e2无法识别为QTextEdit()。仅出于教育目的,将行print e1添加到两个函数中。你会得到:

<PyQt4.QtGui.QTextEdit object at 0x01DA7490>
none

Window()b1_action()打印。因此,您可以在b1_action() e1中找到QTextEdite1中的e2 / Window()e1

中的e2 / b1_action()变量不同

解决这个问题的最简单方法是制作e1e2个全局变量。所以先删除行

e1=None
e2=None

然后将两个变量定义为Window内的全局:

from PyQt4.QtGui import *

def window():
    global e1
    global e2
    app=QApplication(sys.argv)
    win=QWidget()
    win.setWindowTitle("Sample")
    vbox=QVBoxLayout()
    e1 = QTextEdit()
    e2 = QTextEdit()

您可以在此问题中找到有关global variables

的有用信息

通常我不建议基于函数和全局变量构建GUI。查找教程并学习如何使用类。例如this one