RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / user-670582

Lennet8002's questions

Martin Hope
Lennet8002
Asked: 2025-03-23 02:48:06 +0000 UTC

使用 Python 和 Postgresql 开发 Telegram 机器人

  • 5

大家好!我决定在 aiogram3 和 postgresql 上创建一个项目,但是却走进了死胡同。该机器人的任务是接受关键词并使用它们在数据库中搜索信息。也就是说,如果我写/search 80那么它应该通过这个参数给出两个玩家的值(数据库在下面,在这种情况下是lennet和pico),但它只给出1个人的信息。我考虑尝试通过 for 循环来完成此操作,但没有成功。这是基础:在此处输入图片描述

代码如下:

@dp.message(Command('search'))
async def search(message: Message):
    #тут будет поиск в бд
    arg =  message.text.split()  #получаем данные юзера
    args = str(arg.pop(1))  #удаляем элемент т.к arg содержит в себе /search
    try:
        connection = psycopg2.connect(  # конектимся к бд
            host="127.0.0.1",
            user="postgres",
            password="staff",
            database="wow_klass№2",
            port="5432"
        )
        connection.autocommit = True  
        zapros  = f"SELECT * FROM spek WHERE nikname = '{args}' OR class = '{args}' OR spek = '{args}' OR profa = '{args}' OR lvl = '{args}';"
        int = f" SELECT COUNT(*) FROM spek WHERE nikname = '{args}' OR class = '{args}' OR spek = '{args}' OR profa = '{args}' OR lvl = '{args}';"
        ##### запрос  в бд
        with connection.cursor() as iner:
            iner.execute(int)
            integer = iner.fetchone()
        with connection.cursor() as cursor:
            cursor.execute(zapros)
            #закончу тут, появился норм запрос и ответ, осталось реализовать больше 1 участника
            tuple = cursor.fetchone()
            nic = str(tuple[0])
            clas = str(tuple[1])
            spek = str(tuple[2])
            prof = str(tuple[3])
            lvl = str(tuple[4])
            await message.answer(f"Ник игрока: {nic}. \nКласс: {clas}. \nСпек: {spek}. \nПрофесия: {prof}. \nlvl: {lvl}")
    except Exception as _ex:
        print(_ex)
    finally:
        if connection:
            connection.close()
            print("Отсоеденился успешно")
python
  • 1 个回答
  • 30 Views
Martin Hope
Lennet8002
Asked: 2025-01-05 01:09:57 +0000 UTC

Pyqt5和机器人,将输入信息传递给变量

  • 1

我决定将我的《魔兽争霸》机器人放在GUI上。
我使用 Qt Designer 创建了界面并将其转换为 Python 代码。

现在问题来了。
屏幕截图显示了我的机器人(目前只有 gui 图片),我需要将输入的信息传递到变量中,user_info
如何做到这一点?

在此输入图像描述


所有GUI代码:

from PyQt5 import QtCore, QtGui, QtWidgets


class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(349, 471)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.buttonspel = QtWidgets.QLabel(self.centralwidget)
        self.buttonspel.setGeometry(QtCore.QRect(10, 280, 121, 21))
        self.buttonspel.setObjectName("buttonspel")
        self.xhekpail = QtWidgets.QRadioButton(self.centralwidget)
        self.xhekpail.setGeometry(QtCore.QRect(10, 240, 211, 21))
        self.xhekpail.setObjectName("xhekpail")
        self.start = QtWidgets.QPushButton(self.centralwidget)
        self.start.setGeometry(QtCore.QRect(10, 310, 321, 61))
        self.start.setObjectName("start")
        self.buttonspel1 = QtWidgets.QKeySequenceEdit(self.centralwidget)
        self.buttonspel1.setGeometry(QtCore.QRect(130, 280, 81, 20))
        self.buttonspel1.setObjectName("buttonspel1")
        self.Lenbot = QtWidgets.QLabel(self.centralwidget)
        self.Lenbot.setGeometry(QtCore.QRect(10, 10, 281, 111))
        self.Lenbot.setObjectName("Lenbot")
        self.dushnim = QtWidgets.QLabel(self.centralwidget)
        self.dushnim.setGeometry(QtCore.QRect(20, 110, 291, 91))
        self.dushnim.setObjectName("dushnim")
        self.prochital = QtWidgets.QRadioButton(self.centralwidget)
        self.prochital.setGeometry(QtCore.QRect(10, 200, 82, 17))
        self.prochital.setObjectName("prochital")
        self.git = QtWidgets.QLabel(self.centralwidget)
        self.git.setGeometry(QtCore.QRect(10, 380, 291, 21))
        self.git.setObjectName("git")
        self.giturl = QtWidgets.QLabel(self.centralwidget)
        self.giturl.setGeometry(QtCore.QRect(10, 405, 221, 31))
        self.giturl.setObjectName("giturl")
        self.OBIZATELNO = QtWidgets.QLabel(self.centralwidget)
        self.OBIZATELNO.setGeometry(QtCore.QRect(220, 280, 81, 16))
        self.OBIZATELNO.setObjectName("OBIZATELNO")
        MainWindow.setCentralWidget(self.centralwidget)
        self.menubar = QtWidgets.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 349, 21))
        self.menubar.setObjectName("menubar")
        MainWindow.setMenuBar(self.menubar)

        self.retranslateUi(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)
        
        
        self.add_functions()

    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "Len.bot"))
        self.buttonspel.setText(_translate("MainWindow", "введите кнопку спэла"))
        self.xhekpail.setText(_translate("MainWindow", " посмотреть что будер рыспылено"))
        self.start.setText(_translate("MainWindow", "СТАРТ"))
        self.Lenbot.setText(_translate("MainWindow", "<html><head/><body><p align=\"center\"><span style=\" font-weight:600; font-style:italic;\">Len.bot - новый бот, который упрощает гейм-</span></p><p align=\"center\"><span style=\" font-weight:600; font-style:italic;\">плей нашей любимой игры.</span></p><p align=\"center\"><span style=\" font-weight:600; font-style:italic;\">Зачем нам делать нудное дело самим,</span></p><p align=\"center\"><span style=\" font-weight:600; font-style:italic;\">если есть этот бот?</span></p></body></html>" ))
        self.dushnim.setText(_translate("MainWindow", "<html><head/><body><p align=\"center\"><span style=\" font-size:10pt; font-style:italic;\">немного подушним,</span></p><p align=\"center\"><span style=\" font-size:10pt; font-style:italic;\">обязательно прочитай инструкцию,</span></p><p align=\"center\"><span style=\" font-size:10pt; font-style:italic;\">она лежит в папке с ботом</span></p></body></html>"))
        self.prochital.setText(_translate("MainWindow", "прочитал?????????"))
        self.git.setText(_translate("MainWindow", "<html><head/><body><p><span style=\" font-size:12pt; font-weight:600; font-style:italic;\">мой гитхаб-</span></p><p><span style=\" font-size:12pt;\"><br/></span></p></body></html>"))
        self.giturl.setText(_translate("MainWindow", "<html><head/><body><p><span style=\" font-size:10pt; font-weight:600;\">https://github.com/Lennet8002</span></p></body></html>"))
        self.OBIZATELNO.setText(_translate("MainWindow", "ОБЯЗАТЕЛЬНО!"))
        
    def add_functions(self):
        self.xhekpail.clicked.connect(self.pail_chek)    #запомнить 25минут
        self.start.clicked.connect(self.start_chek)
        self.buttonspel.
        
    def pail_chek(self):
        user_info = "yes"
        
    def start_chek(self):
        start = "enter"

if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)
    MainWindow = QtWidgets.QMainWindow()
    ui = Ui_MainWindow()
    ui.setupUi(MainWindow)
    MainWindow.show()
    sys.exit(app.exec_())
python
  • 1 个回答
  • 27 Views
Martin Hope
Lennet8002
Asked: 2025-01-01 19:33:45 +0000 UTC

在屏幕截图中搜索模板

  • 6

最近我开始为魔兽世界(3.3.5)游戏编写一个机器人,为此我必须了解cv2,但我仍然不明白它,下面是代码:

import cv2
import numpy as np
import os
     
screenshot = cv2.imread('scren.png')
     
template_folder = 'tem_1'
templates = [cv2.imread(os.path.join(template_folder, f))
                for f in os.listdir(template_folder) if f.endswith('.png')]
        
threshold = 0.8   
coordinates = []
        
def are_points_close(pt1, pt2, threshold_distance=40):
    return np.linalg.norm(np.array(pt1) - np.array(pt2)) < threshold_distance
        
for template in templates:
    result = cv2.matchTemplate(
        screenshot, template, cv2.TM_CCOEFF_NORMED)
    loc = np.where(result >= threshold)
    
    # Отметьте найденные шаблоны
    for pt in zip(*loc[::-1]):  # Переворот координат
        cv2.rectangle(
            screenshot, pt, (pt[0] + template.shape[1], pt[1] + template.shape[0]), (0, 255, 255), 2)
        coordinates.append((pt))
       
print(coordinates)
      
cv2.imwrite('output.png', screenshot)     
cv2.imshow('Detected Templates', screenshot) 
cv2.waitKey(0)  
cv2.destroyAllWindows()

它会在屏幕上圈出模板并显示其坐标以供进一步迭代,但代码返回给我:

np.int64(575)), (np.int64(1427), np.int64(575)), (np.int64(1428), np.int64(575)), (np.int64(1427), np. int64(576)), (np.int64(1654), np.int64(689)), (np.int64(1655),np.int64(689)),(np.int64(1656),np.int64(689)),(np.int64(1655),np.int64(690)),(np .int64(1655), np.int64(404....

一切看起来都很正常,但关键是屏幕上只有4 个东西,而且有很多坐标,它们相差1-3个值,机器人找到东西并选择它们,但不知何故它得到了太多他们。

以下是模板和屏幕截图:在此输入图像描述 在此输入图像描述 在此输入图像描述 在此输入图像描述

在此输入图像描述

前三个是模板,然后是屏幕,以及机器人找到的内容。

python
  • 1 个回答
  • 38 Views

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5