取引先保守(検索機能付) 子ウィンド利用
取引先保守(親ウィンド)
mnttorihikisaki.ui mnttorihikisaki.py MntTorihikisaki.project QtCreator で作成
pyside6-uic mnttorihikisaki.ui -o ui_mnttorihikisaki.py
取引先検索(子ウィンド)
kentorihikisaki.ui kentorihikisaki.py kentorihikisaki.project QtCreator で作成
signals と slots を buttonBox へ設定します。子ウィンドの戻り値をセットします。
pyside6-uic kentorihikisaki.ui -o ui_kentorihikisaki.py
取引先保守の作成
MntTorihikisaki のフォルダーへ ui_kentorihikisaki.py をコピーする
mnttorihikisaki.py
# This Python file uses the following encoding: utf-8
import os
from pathlib import Path
import sys
import io
import csv
from datetime import date,datetime
from PySide6 import *
from PySide6.QtCore import *
from PySide6.QtGui import *
from PySide6.QtWidgets import *
# Important:
# You need to run the following command to generate the ui_form.py file
# pyside6-uic form.ui -o ui_form.py, or
# pyside2-uic form.ui -o ui_form.py
from ui_mnttorihikisaki import Ui_MntTorihikisaki
from ui_kentorihikisaki import Ui_kentorihikisaki
import pymssql
server = '192.168.10.111'
username = 'sa'
password = 'xxxxxxxx'
database = 'kakei'
try:
conn = pymssql.connect( server , username , password, database )
except Exception as e:
print('接続エラー' + e.args)
else:
pass
class SimpleTableModel(QAbstractTableModel):
def __init__(self, list, headers = [], parent = None):
QAbstractTableModel.__init__(self, parent)
self.list = list
self.headers = headers
def rowCount(self, parent):
return len(self.list)
def columnCount(self, parent):
return len(self.list[0])
def flags(self, index):
return Qt.ItemIsEditable | Qt.ItemIsEnabled | Qt.ItemIsSelectable #Qt.ItemIsEditable | Qt.ItemIsEnabled | Qt.ItemIsSelectable
def data(self, index, role):
if role == Qt.EditRole:
row = index.row()
column = index.column()
return self.list[row][column]
elif role == Qt.DisplayRole:
row = index.row()
column = index.column()
value = self.list[row][column]
# Perform per-type checks and render accordingly.
if isinstance(value, datetime):
# Render time to YYY-MM-DD.
return value.strftime("%Y-%m-%d")
elif isinstance(value, int):
# Render int to 0 dp
return "%d" % value
elif isinstance(value, float):
# Render float to 2 dp
return "%.2f" % value
elif isinstance(value, str):
# Render strings with quotes
return "%s" % value
# Default (anything not captured above: e.g. int)
else:
return value
elif role == Qt.TextAlignmentRole:
row = index.row()
column = index.column()
value = self.list[row][column]
if isinstance(value, int) or isinstance(value, float) or column == 2 or column == 3 or column == 4 :#例外とした
# Align right, vertical middle.
return int(Qt.AlignRight) + int(Qt.AlignVCenter)#,Qt.AlignHCenter,Qt.AlignRight,Qt.AlignCenter,Qt.AlignTop,Qt.AlignVCenter,Qt.AlignBottom
else:
return int(Qt.AlignLeft) + int(Qt.AlignVCenter)
def setData(self, index, value, role= Qt.EditRole):
if role == Qt.EditRole:
row = index.row()
column = index.column()
self.list[row][column] = value
self.dataChanged.emit(index, index)
return True
return False
def headerData(self, section, orientation, role):
if role == Qt.DisplayRole:
if orientation == Qt.Horizontal:
if section < len(self.headers):
return self.headers[section]
else:
return "not implemented"
else:
return "%d" % (section + 1)
class ValClass:
sonzai = 0
class MntTorihikisaki(QMainWindow):
def __init__(self, parent=None):
super().__init__(parent)
self.ui = Ui_MntTorihikisaki()
self.ui.setupUi(self)
self.popup_dlg = None
# フォームと動作の関連付け
self.ui.pushButton_4.clicked.connect(self.sub_dlg)
self.ui.lineEdit.returnPressed.connect(self.select)
self.ui.lineEdit_2.returnPressed.connect(self.edit_2)
self.ui.lineEdit_3.returnPressed.connect(self.edit_3)
self.ui.lineEdit_4.returnPressed.connect(self.edit_4)
self.ui.lineEdit_5.returnPressed.connect(self.edit_5)
self.ui.lineEdit_6.returnPressed.connect(self.edit_6)
self.ui.lineEdit_7.returnPressed.connect(self.edit_7)
self.ui.lineEdit_8.returnPressed.connect(self.edit_8)
self.ui.pushButton.clicked.connect(self.koshin)
self.ui.pushButton_2.clicked.connect(self.sakujo)
self.ui.pushButton_3.clicked.connect(self.exit)
self.ui.pushButton_5.clicked.connect(self.torikeshi)
self.ui.label.setStyleSheet("background-color: pink")
self.ui.label_2.setStyleSheet("background-color: violet")
self.ui.label_3.setStyleSheet("background-color: violet")
self.ui.label_4.setStyleSheet("background-color: violet")
self.ui.label_5.setStyleSheet("background-color: violet")
self.ui.label_6.setStyleSheet("background-color: violet")
self.ui.label_7.setStyleSheet("background-color: violet")
self.ui.label_8.setStyleSheet("background-color: violet")
self.ui.label_9.setStyleSheet("background-color: violet")
self.ui.label_10.setStyleSheet("background-color: aqua")
self.ui.pushButton.setStyleSheet("background-color: aqua")
self.ui.pushButton_2.setStyleSheet("background-color: yellow")
self.ui.pushButton_3.setStyleSheet("background-color: green")
self.ui.pushButton_4.setStyleSheet("background-color: blue")
self.ui.pushButton_5.setStyleSheet("background-color: violet")
def sub_dlg(self):
dialog = Subkentorihikisaki()
if dialog.exec():
self.ui.lineEdit.setText(dialog.dlg.lineEdit.text())
self.ui.lineEdit.setFocus()
def exit(self): #-> None:
sys.exit()
#self.close()
def torikeshi(self):
self.ui.lineEdit_2.setText('')
self.ui.lineEdit_3.setText('')
self.ui.lineEdit_4.setText('')
self.ui.lineEdit_5.setText('')
self.ui.lineEdit_6.setText('')
self.ui.lineEdit_7.setText('')
self.ui.lineEdit_8.setText('')
self.ui.label_10.setText('')
self.ui.lineEdit.setEnabled(True)
self.ui.lineEdit.setFocus()
def select(self):
codestr = self.ui.lineEdit.text()
try:
codeint = int(codestr)
except:
QMessageBox.warning(self,'エラー','数値エラー')
self.ui.lineEdit.setFocus()
return
else:
if codeint <= 0 or codeint > 9999:
QMessageBox.warning(self,'エラー','コードエラー')
self.ui.lineEdit.setFocus()
return
try:
tablenm = "取引先マスター"
cursor = conn.cursor()
sql = "select * from " + tablenm
sql += " where 取引先コード = " + str(codeint)
sql += " order by 取引先コード"
cursor.execute(sql)
results = cursor.fetchall()
sonzai = 0
for res in results:
self.ui.lineEdit_2.setText(str(res[1]))
self.ui.lineEdit_3.setText(str(res[2]))
self.ui.lineEdit_4.setText(str(res[3]))
self.ui.lineEdit_5.setText(str(res[4]))
self.ui.lineEdit_6.setText(str(res[5]))
self.ui.lineEdit_7.setText(str(res[6]))
self.ui.lineEdit_8.setText(str(res[7]))
sonzai = 1
except Exception as e:
QMessageBox.warning(self,'エラー','selectエラー' + e.args)
else:
pass
cursor.close()
self.ui.lineEdit.setEnabled(False)
self.ui.lineEdit_2.setFocus()
if sonzai == 1:
self.ui.label_10.setText('既 存')
else:
self.ui.label_10.setText('新 規')
self.ui.lineEdit_2.setText('')
self.ui.lineEdit_3.setText('0')
self.ui.lineEdit_4.setText('0')
self.ui.lineEdit_5.setText('0')
self.ui.lineEdit_6.setText('')
self.ui.lineEdit_7.setText('')
self.ui.lineEdit_8.setText('')
ValClass.sonzai = sonzai
return
def edit_2(self):
self.ui.lineEdit_2.focusNextChild()
def edit_3(self):
codestr = self.ui.lineEdit_3.text()
try:
codeint = int(codestr)
except:
QMessageBox.warning(self,'エラー','数値エラー')
self.ui.lineEdit_3.setFocus()
return
else:
if codeint < 0 or codeint > 9:
QMessageBox.warning(self,'エラー','コードエラー')
self.ui.lineEdit_3.setFocus()
return
self.ui.lineEdit_3.focusNextChild()
def edit_4(self):
codestr = self.ui.lineEdit_4.text()
try:
codeint = int(codestr)
except:
QMessageBox.warning(self,'エラー','数値エラー')
self.ui.lineEdit_4.setFocus()
return
else:
if codeint < 0 or codeint > 9999:
QMessageBox.warning(self,'エラー','コードエラー')
self.ui.lineEdit_4.setFocus()
return
self.ui.lineEdit_4.focusNextChild()
def edit_5(self):
codestr = self.ui.lineEdit_5.text()
try:
codeint = int(codestr)
except:
QMessageBox.warning(self,'エラー','数値エラー')
self.ui.lineEdit_5.setFocus()
return
else:
if codeint < 0 or codeint > 999:
QMessageBox.warning(self,'エラー','コードエラー')
self.ui.lineEdit_5.setFocus()
return
self.ui.lineEdit_5.focusNextChild()
def edit_6(self):
self.ui.lineEdit_6.focusNextChild()
def edit_7(self):
self.ui.lineEdit_7.focusNextChild()
def edit_8(self):
self.ui.lineEdit_2.setFocus()
def koshin(self):
try:
v1 = int(self.ui.lineEdit.text())
v3 = int(self.ui.lineEdit_3.text())
v4 = int(self.ui.lineEdit_4.text())
v5 = int(self.ui.lineEdit_5.text())
except:
QMessageBox.warning(self,'エラー','数値エラー')
self.ui.lineEdit_3.setFocus()
return
else:
if v1 <= 0 or v1 > 9999:
QMessageBox.warning(self,'エラー','取引先コードエラー')
self.ui.lineEdit.setFocus()
return
elif v3 < 0 or v3 > 9:
QMessageBox.warning(self,'エラー','取引先区分エラー')
self.ui.lineEdit_3.setFocus()
return
elif v4 < 0 or v4 > 9999:
QMessageBox.warning(self,'エラー','銀行コードエラー')
self.ui.lineEdit_4.setFocus()
return
elif v5 < 0 or v5 > 999:
QMessageBox.warning(self,'エラー','支店コードエラー')
self.ui.lineEdit_5.setFocus()
return
v2 = self.ui.lineEdit_2.text()
v6 = self.ui.lineEdit_6.text()
v7 = self.ui.lineEdit_7.text()
v8 = self.ui.lineEdit_8.text()
if ValClass.sonzai == 0: #新規
sqlstr = " insert into 取引先マスター (取引先コード,取引先名,取引先区分,銀行コード,支店コード,口座番号,名義人,備考) "
sqlstr += " values ( " + str(v1) + ",'" + v2 + "'," + str(v3) + "," + str(v4) + "," + str(v5) + ",'"
sqlstr += v6 + "','" + v7 + "','" + v8 + "')"
else: #既存
sqlstr = " update 取引先マスター "
sqlstr += " set "
sqlstr += " 取引先名 = '" + v2 + "'"
sqlstr += ",取引先区分 = " + str(v3)
sqlstr += ",銀行コード = " + str(v4)
sqlstr += ",支店コード = " + str(v5)
sqlstr += ",口座番号 = '" + v6 + "'"
sqlstr += ",名義人 = '" + v7 +"'"
sqlstr += ",備考 = '" + v8 +"'"
sqlstr += " where 取引先コード = " + str(v1)
try:
cursor = conn.cursor()
cursor.execute(sqlstr)
except Exception as e:
QMessageBox.warning(self,'結 果','更新できません。' + sqlstr)
cursor.close()
self.ui.lineEdit_2.setFocus()
return
else:
pass
conn.commit()
cursor.close()
QMessageBox.warning(self,'結 果','更新しました。')
self.torikeshi()
self.ui.lineEdit.setFocus()
def sakujo(self):
if ValClass.sonzai == 0:
QMessageBox.warning(self,'結 果','更新できません。レコードなし')
try:
v1 = int(self.ui.lineEdit.text())
except:
QMessageBox.warning(self,'エラー','数値エラー')
self.ui.lineEdit.setFocus()
return
else:
if v1 <= 0 or v1 > 9999:
QMessageBox.warning(self,'エラー','取引先コードエラー')
self.ui.lineEdit.setFocus()
return
sqlstr = " delete from 取引先マスター "
sqlstr += " where 取引先コード = " + str(v1)
try:
cursor = conn.cursor()
cursor.execute(sqlstr)
except Exception as e:
QMessageBox.warning(self,'結 果','削除できません。' + sqlstr )
cursor.close()
self.ui.lineEdit.setFocus()
return
else:
pass
conn.commit()
cursor.close()
QMessageBox.warning(self,'結 果','削除しました。')
self.torikeshi()
self.ui.lineEdit.setFocus()
class Subkentorihikisaki(QDialog):
def __init__(self, parent=None):
super().__init__(parent)
self.dlg = Ui_kentorihikisaki()
self.dlg.setupUi(self)
self.view()
self.dlg.tableView.clicked.connect(self.valset)
def valset(self):
selection = self.dlg.tableView.selectedIndexes()
if selection:
rows = sorted(index.row() for index in selection)
columns = sorted(index.column() for index in selection)
rowcount = rows[-1] - rows[0] + 1
colcount = columns[-1] - columns[0] + 1
table = [[''] * colcount for _ in range(rowcount)]
for index in selection:
row = index.row() - rows[0]
column = index.column() - columns[0]
table[row][column] = index.data()
self.dlg.lineEdit.setText(str(table[0][0]))
def view(self):
server = '192.168.10.111'
username = 'sa'
password = 'xxxxxxxx'
database = 'kakei'
try:
conn = pymssql.connect( server , username , password, database )
cursor = conn.cursor()
sqlstr = " select * from 取引先マスター "
sqlstr += " order by 取引先コード"
cursor.execute(sqlstr)
results = cursor.fetchall()
# データを表示
coldata = ['コード','取引先名','取引先区分']
rowdata = []
row = 0
for res in results:
i=0
rowone = []
while i <= 2:
try:
strint = int(str(res[i]))
strfloat = float(str(res[i]))
if strint == strfloat:
rowone.append(strint)
else:
rowone.append(strfloat)
except:
rowone.append(str(res[i]))
else:
pass
i += 1
row += 1
rowdata.append(rowone)
model = SimpleTableModel(rowdata, coldata)
self.dlg.tableView.setModel(model) # create model and set
self.dlg.tableView.horizontalHeader().setSectionResizeMode(QHeaderView.ResizeToContents) #列幅の自動調整 0:Interactive 1:Stretch 2:Fixed 3:ResizeToContents
cursor.close()
conn.close()
except Exception as e:
QMessageBox.warning(self,'エラー','接続エラー' + e.args)
else:
pass
if __name__ == "__main__":
app = QApplication(sys.argv)
widget = MntTorihikisaki()
widget.show()
sys.exit(app.exec())
実行画面
検索ボタン押下
セブンプラスの行をクリック
OKボタン押下
検索画面で選択した値がセットされます。