button_layout = QHBoxLayout() button1 = QPushButton('当日员工工资') button1.clicked.connect(self.show_query1_result) button2 = QPushButton('当日鸡爪领取记录') button2.clicked.connect(self.show_query2_result) button3 = QPushButton('查询历史员工工资') button3.clicked.connect(self.show_query3_result) button4 = QPushButton('查询历史鸡爪领取记录') button4.clicked.connect(self.show_query4_result) button_layout.addWidget(button1) button_layout.addWidget(button2) button_layout.addWidget(button3) button_layout.addWidget(button4)怎么把这4个按钮改为竖向排列
时间: 2023-07-16 09:15:19 浏览: 211
可以使用QVBoxLayout代替QHBoxLayout,具体代码如下:
```
button_layout = QVBoxLayout()
button1 = QPushButton('当日员工工资')
button1.clicked.connect(self.show_query1_result)
button2 = QPushButton('当日鸡爪领取记录')
button2.clicked.connect(self.show_query2_result)
button3 = QPushButton('查询历史员工工资')
button3.clicked.connect(self.show_query3_result)
button4 = QPushButton('查询历史鸡爪领取记录')
button4.clicked.connect(self.show_query4_result)
button_layout.addWidget(button1)
button_layout.addWidget(button2)
button_layout.addWidget(button3)
button_layout.addWidget(button4)
```
这样就可以实现垂直排列了。
相关问题
class MainWindow(QMainWindow): def init(self): super().init() # 设置主窗口大小 self.setFixedSize(800, 600) self.setWindowFlags(Qt.WindowMinimizeButtonHint | Qt.WindowMaximizeButtonHint | Qt.WindowCloseButtonHint) # 创建主窗口布局 main_layout = QVBoxLayout() central_widget = QWidget() central_widget.setLayout(main_layout) self.setCentralWidget(central_widget) # 创建两个竖向按钮 button_layout = QVBoxLayout() button1 = QPushButton('当日员工工资') button1.setFixedSize(200, 50) button1.clicked.connect(self.show_query1_result) button_layout.addStretch() button_layout.addWidget(button1) button_layout.addStretch() layout = QHBoxLayout() layout.addStretch() layout.addLayout(button_layout) layout.addStretch() widget = QWidget() widget.setLayout(layout) self.setCentralWidget(widget) # 将按钮布局添加到主窗口布局中 main_layout.addLayout(button_layout) # 创建两个窗口用于展示查询结果 self.query1_window = QueryResultWindow() def show_query1_result(self): # 查询数据 db = pymysql.connect(host='39.99.214.172', user='root', password='Solotion.123', db='jj_tset') cursor = db.cursor() db_sql = """ SELECT *,salary + weight_reward total_salary from ( SELECT a.user_id,user_name,get_time,get_kg,efficiency,CONCAT(ROUND(ROUND(yield_rate,4) * 100,2),'%') yield_rate,ROUND(get_kg * 2 * price,1) salary,CASE WHEN yield_rate > 0.64 and get_kg < 40 THEN kg1_price WHEN yield_rate > 0.64 and get_kg < 50 THEN kg2_price WHEN yield_rate > 0.64 and get_kg >= 50 THEN kg3_price WHEN yield_rate < 0.64 THEN 0 END as weight_reward FROM (SELECT user_id, DATE_FORMAT(get_time,'%Y-%m-%d') get_time, SUM(get_kg) get_kg,round(SUM(get_kg)/(SUM(duration_time)/3600),2) efficiency,AVG(yield_rate) yield_rate FROM em_salary WHERE DATE_FORMAT(get_time,'%Y-%m-%d') = DATE_FORMAT(DATE_SUB(NOW(),INTERVAL 0 DAY),'%Y-%m-%d') and recycle_kg IS NOT NULL GROUP BY user_id, DATE_FORMAT(get_time,'%Y-%m-%d')) a LEFT JOIN (SELECT user_id,name as user_name,price,kg1_price,kg2_price,kg3_price,yield_price FROM employee_table CROSS JOIN price_data ) d on a.user_id = d.user_id ) T """ cursor.execute(db_sql) result = cursor.fetchall() db.close() if len(result) == 0: QMessageBox.information(self, "提示", "今日无员工工资记录") return self.query1_window.table_widget.setRowCount(0) self.query1_window.table_widget.setColumnCount(len(result[0])) self.query1_window.table_widget.setHorizontalHeaderLabels( ["员工ID", "员工姓名", "日期", "领取鸡爪重量(KG)", "效率(每小时KG)", "出成率", "基础工资", "重量奖励", "当日总工资"]) for row_num, row_data in enumerate(result): self.query1_window.table_widget.insertRow(row_num) for col_num, col_data in enumerate(row_data): self.query1_window.table_widget.setItem(row_num, col_num, QTableWidgetItem(str(col_data))) self.query1_window.show()怎么改为按ID查询数据
要按照员工ID查询数据,你需要更改SQL语句。以下是更改后的SQL语句:
```
SELECT *,salary + weight_reward total_salary
FROM (
SELECT a.user_id,user_name,get_time,get_kg,efficiency,CONCAT(ROUND(ROUND(yield_rate,4) * 100,2),'%') yield_rate,
ROUND(get_kg * 2 * price,1) salary,
CASE
WHEN yield_rate > 0.64 and get_kg < 40 THEN kg1_price
WHEN yield_rate > 0.64 and get_kg < 50 THEN kg2_price
WHEN yield_rate > 0.64 and get_kg >= 50 THEN kg3_price
WHEN yield_rate < 0.64 THEN 0
END as weight_reward
FROM (
SELECT user_id, DATE_FORMAT(get_time,'%Y-%m-%d') get_time,
SUM(get_kg) get_kg,
round(SUM(get_kg)/(SUM(duration_time)/3600),2) efficiency,
AVG(yield_rate) yield_rate
FROM em_salary
WHERE DATE_FORMAT(get_time,'%Y-%m-%d') = DATE_FORMAT(DATE_SUB(NOW(),INTERVAL 0 DAY),'%Y-%m-%d')
AND recycle_kg IS NOT NULL
GROUP BY user_id, DATE_FORMAT(get_time,'%Y-%m-%d')
) a
LEFT JOIN (
SELECT user_id,name as user_name,price,kg1_price,kg2_price,kg3_price,yield_price
FROM employee_table CROSS JOIN price_data
) d ON a.user_id = d.user_id
WHERE a.user_id = '{id}'
) T
```
在这个SQL语句中,我们添加了一个WHERE子句来过滤出指定ID的员工数据。在Python代码中,你需要将SQL语句中的{id}替换为你要查询的员工ID。你可以使用QInputDialog来输入员工ID,然后将其传递给SQL语句:
```
from PyQt5.QtWidgets import QInputDialog
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
# ...
self.query1_window = QueryResultWindow()
def show_query1_result(self):
# 获取员工ID
id, ok = QInputDialog.getText(self, '输入员工ID', '请输入员工ID:')
if not ok:
return
# 查询数据
db = pymysql.connect(host='39.99.214.172', user='root', password='Solotion.123', db='jj_tset')
cursor = db.cursor()
db_sql = """
SELECT *,salary + weight_reward total_salary
FROM (
SELECT a.user_id,user_name,get_time,get_kg,efficiency,CONCAT(ROUND(ROUND(yield_rate,4) * 100,2),'%') yield_rate,
ROUND(get_kg * 2 * price,1) salary,
CASE
WHEN yield_rate > 0.64 and get_kg < 40 THEN kg1_price
WHEN yield_rate > 0.64 and get_kg < 50 THEN kg2_price
WHEN yield_rate > 0.64 and get_kg >= 50 THEN kg3_price
WHEN yield_rate < 0.64 THEN 0
END as weight_reward
FROM (
SELECT user_id, DATE_FORMAT(get_time,'%Y-%m-%d') get_time,
SUM(get_kg) get_kg,
round(SUM(get_kg)/(SUM(duration_time)/3600),2) efficiency,
AVG(yield_rate) yield_rate
FROM em_salary
WHERE DATE_FORMAT(get_time,'%Y-%m-%d') = DATE_FORMAT(DATE_SUB(NOW(),INTERVAL 0 DAY),'%Y-%m-%d')
AND recycle_kg IS NOT NULL
AND user_id = '{id}'
GROUP BY user_id, DATE_FORMAT(get_time,'%Y-%m-%d')
) a
LEFT JOIN (
SELECT user_id,name as user_name,price,kg1_price,kg2_price,kg3_price,yield_price
FROM employee_table CROSS JOIN price_data
) d ON a.user_id = d.user_id
) T
""".format(id=id)
cursor.execute(db_sql)
result = cursor.fetchall()
db.close()
if len(result) == 0:
QMessageBox.information(self, "提示", "今日无员工工资记录")
return
self.query1_window.table_widget.setRowCount(0)
self.query1_window.table_widget.setColumnCount(len(result[0]))
self.query1_window.table_widget.setHorizontalHeaderLabels(
["员工ID", "员工姓名", "日期", "领取鸡爪重量(KG)", "效率(每小时KG)", "出成率", "基础工资", "重量奖励", "当日总工资"]
)
for row_num, row_data in enumerate(result):
self.query1_window.table_widget.insertRow(row_num)
for col_num, col_data in enumerate(row_data):
self.query1_window.table_widget.setItem(row_num, col_num, QTableWidgetItem(str(col_data)))
self.query1_window.show()
```
这样,你就可以按照员工ID查询工资记录了。
button_layout = QVBoxLayout() button1 = QPushButton('当日员工工资') button1.setFixedSize(200, 50) button1.setStyleSheet('QPushButton {background-color: #A3C1DA; color: black; font-weight: bold;}') button1.clicked.connect(self.show_query1_result) button2 = QPushButton('当日鸡爪领取记录') button2.setFixedSize(200, 50) button2.setStyleSheet('QPushButton {background-color: #A3C1DA; color: black; font-weight: bold;}') button2.clicked.connect(self.show_query2_result) button3 = QPushButton('查询历史员工工资') button3.setFixedSize(200, 50) button3.setStyleSheet('QPushButton {background-color: #A3C1DA; color: black; font-weight: bold;}') button3.clicked.connect(self.show_query3_result) button4 = QPushButton('查询历史鸡爪领取记录') button4.setFixedSize(200, 50) button4.setStyleSheet('QPushButton {background-color: #A3C1DA; color: black; font-weight: bold;}') button4.clicked.connect(self.show_query4_result) button5 = QPushButton('按员工ID查询员工工资') button5.setFixedSize(200, 50) button5.setStyleSheet('QPushButton {background-color: #A3C1DA; color: black; font-weight: bold;}') button5.clicked.connect(self.show_query5_result) button6 = QPushButton('按员工ID查询鸡爪领取记录') button6.setFixedSize(200, 50) button6.setStyleSheet('QPushButton {background-color: #A3C1DA; color: black; font-weight: bold;}') button6.clicked.connect(self.show_query6_result) button_layout.addStretch() button_layout.addWidget(button1) button_layout.addWidget(button2) button_layout.addWidget(button3) button_layout.addWidget(button4) button_layout.addWidget(button5) button_layout.addWidget(button6) button_layout.addStretch() layout = QHBoxLayout() layout.addStretch() layout.addLayout(button_layout) layout.addStretch() widget = QWidget() widget.setLayout(layout) self.setCentralWidget(widget) # 将按钮布局添加到主窗口布局中 main_layout.addLayout(button_layout) # 创建两个窗口用于展示查询结果 self.query1_window = QueryResultWindow() self.query2_window = QueryResultWindow() self.query3_window = QueryResultWindow() self.query4_window = QueryResultWindow() self.query5_window = QueryResultWindow() self.query6_window = QueryResultWindow()怎么设置按钮位置为两列
要将按钮布局设置为两列,可以使用QGridLayout而不是QVBoxLayout。可以使用addWidget()方法将按钮添加到布局中,并指定它们的位置。以下是示例代码:
```
button_layout = QGridLayout()
button1 = QPushButton('当日员工工资')
button1.setFixedSize(200, 50)
button1.setStyleSheet('QPushButton {background-color: #A3C1DA; color: black; font-weight: bold;}')
button1.clicked.connect(self.show_query1_result)
button_layout.addWidget(button1, 0, 0)
button2 = QPushButton('当日鸡爪领取记录')
button2.setFixedSize(200, 50)
button2.setStyleSheet('QPushButton {background-color: #A3C1DA; color: black; font-weight: bold;}')
button2.clicked.connect(self.show_query2_result)
button_layout.addWidget(button2, 0, 1)
button3 = QPushButton('查询历史员工工资')
button3.setFixedSize(200, 50)
button3.setStyleSheet('QPushButton {background-color: #A3C1DA; color: black; font-weight: bold;}')
button3.clicked.connect(self.show_query3_result)
button_layout.addWidget(button3, 1, 0)
button4 = QPushButton('查询历史鸡爪领取记录')
button4.setFixedSize(200, 50)
button4.setStyleSheet('QPushButton {background-color: #A3C1DA; color: black; font-weight: bold;}')
button4.clicked.connect(self.show_query4_result)
button_layout.addWidget(button4, 1, 1)
button5 = QPushButton('按员工ID查询员工工资')
button5.setFixedSize(200, 50)
button5.setStyleSheet('QPushButton {background-color: #A3C1DA; color: black; font-weight: bold;}')
button5.clicked.connect(self.show_query5_result)
button_layout.addWidget(button5, 2, 0)
button6 = QPushButton('按员工ID查询鸡爪领取记录')
button6.setFixedSize(200, 50)
button6.setStyleSheet('QPushButton {background-color: #A3C1DA; color: black; font-weight: bold;}')
button6.clicked.connect(self.show_query6_result)
button_layout.addWidget(button6, 2, 1)
button_layout.setColumnStretch(2, 1) # 添加空白列来填充布局
layout = QHBoxLayout()
layout.addLayout(button_layout)
widget = QWidget()
widget.setLayout(layout)
self.setCentralWidget(widget)
```
在上面的代码中,`button_layout`是一个QGridLayout,使用addWidget()方法来添加按钮到布局中,并指定它们的行和列。`setColumnStretch()`方法用于添加一个空白列来填充布局,使其呈现为两列。
阅读全文