如何解决以下问题 我无法从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()
答案 0 :(得分:0)
这里的问题是,在b1_action()
中,变量e1
和e2
无法识别为QTextEdit()
。仅出于教育目的,将行print e1
添加到两个函数中。你会得到:
<PyQt4.QtGui.QTextEdit object at 0x01DA7490>
none
从Window()
和b1_action()
打印。因此,您可以在b1_action()
e1
中找到QTextEdit
。 e1
中的e2
/ Window()
与e1
e2
/ b1_action()
变量不同
解决这个问题的最简单方法是制作e1
和e2
个全局变量。所以先删除行
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