Форум сайта python.su
# -*- coding: utf-8 -*- import urllib.parse import urllib.request import re, os, sys def findyoutube(x): mas = [] sq = 'http://www.youtube.com/results?search_query=' + urllib.parse.quote(x) doc = urllib.request.urlopen(sq).read().decode('utf8', errors='ignore') match = re.findall(r'(?P<v>=(.+?)")+.*(title="(.+?)")', doc) if not (match is None): for ii in match: if (len(ii) < 25): mas.append(ii[3] + '\n*replace*' + ii[1] + '\n') mas = dict(zip(mas, mas)).values() mas2 = [] for y in mas: mas2.append(f'{y}'.replace('*replace*', 'http://www.youtube.com/watch?v=')) return mas2 print(findyoutube('болонская+удочка°')) with open('output.txt', 'w', encoding='utf8') as output: for i in findyoutube('болонская+удочка'): output.write(i + '\n')
# ./cloudflared-linux-arm64 tunnel login Please open the following URL and log in with your Cloudflare account: https://dash.cloudflare.com/argotunnel?callback=https%3A%2F%2Flogin.cloudflareaccess.org%2FES4Xk39csUQbzK8SnGjmM8U4vEvEXyAG81QCs9nmRmo%3D Leave cloudflared running to download the cert automatically.
# ./cloudflared-linux-arm64 tunnel login | tee log.txt
username = pyinputplus.inputNum('Username (must be 12 numbers): ', min=111111111111, max=999999999999, limit=3)
def CreateMessage(title, icon, text, informative_text): MESSAGE=QMessageBox() MESSAGE.setWindowTitle(title) MESSAGE.setIcon(icon) MESSAGE.setText(text) MESSAGE.setInformativeText(informative_text) MESSAGE.setStandardButtons(QMessageBox.Ok) MESSAGE.exec_()
CreateMessage('Ошибка', QMessageBox.Critical, f'Доменное имя {domain} не поддерживается', None)
import string import random import zipfile PASSWORD_LENGTH = 4 def extract_archive(file_to_open, password): """ Функция открывает архив с паролем и возвращает результат операции (bool) """ try: file_to_open.extractall(pwd=password.encode()) return True except Exception as e: print(e) return False def hack_archive(file_name): """ Функция брутфорсит запароленный архив """ file_to_open = zipfile.ZipFile(file_name) # объект архива wrong_passwords = [] # список паролей, которые не подошли tries = 0 # колличество неудачных попыток while True: """ Здесь необходимо реализовать: 1. Случайную генерацию пароля, который будет соответствовать условиям: * длина - 4 символа (`PASSWORD_LENGTH`) * допустимые символы пароля - только цифры * type(password) == str 2. Открытие архива со сгенерированым паролем - `extract_archive(file_to_open, password)` При удачном открытии (True) - прервать цикл При неудачи (False) - добавить пароль в список `wrong_passwords` и больше не проверять данный пароль 3. Счетчик неудачных попыток """ print(f'Archive {file_name} is hacked. Password - {password}') print(f'Password was found after {tries} tries') ############# filename = 'task.zip' hack_archive(filename)
import data as mod if __name__ == '__main__': object = mod.Facility() mod.mouse.visible = True mod.window.borderless = False object.run()
from PyQt5 import QtCore, QtGui, QtWidgets import main #1) class Ui_Dialog(object): def setupUi(self, Dialog): Dialog.setObjectName("Dialog") Dialog.resize(1013, 854) self.label = QtWidgets.QLabel(Dialog) self.label.setGeometry(QtCore.QRect(10, 250, 171, 31)) font = QtGui.QFont() font.setPointSize(14) self.label.setFont(font) self.label.setObjectName("label") self.label_2 = QtWidgets.QLabel(Dialog) self.label_2.setGeometry(QtCore.QRect(10, 340, 571, 31)) font = QtGui.QFont() font.setPointSize(14) self.label_2.setFont(font) self.label_2.setObjectName("label_2") self.textEdit_2 = QtWidgets.QTextEdit(Dialog) self.textEdit_2.setGeometry(QtCore.QRect(10, 380, 181, 31)) self.textEdit_2.setObjectName("textEdit_2") self.label_3 = QtWidgets.QLabel(Dialog) self.label_3.setGeometry(QtCore.QRect(10, 440, 391, 31)) font = QtGui.QFont() font.setPointSize(14) self.label_3.setFont(font) self.label_3.setObjectName("label_3") self.textEdit_3 = QtWidgets.QTextEdit(Dialog) self.textEdit_3.setGeometry(QtCore.QRect(10, 480, 181, 31)) self.textEdit_3.setObjectName("textEdit_3") self.label_4 = QtWidgets.QLabel(Dialog) self.label_4.setGeometry(QtCore.QRect(10, 530, 371, 31)) font = QtGui.QFont() font.setPointSize(14) self.label_4.setFont(font) self.label_4.setObjectName("label_4") self.textEdit_4 = QtWidgets.QTextEdit(Dialog) self.textEdit_4.setGeometry(QtCore.QRect(10, 560, 181, 31)) self.textEdit_4.setObjectName("textEdit_4") self.label_5 = QtWidgets.QLabel(Dialog) self.label_5.setGeometry(QtCore.QRect(0, 610, 501, 31)) font = QtGui.QFont() font.setPointSize(14) self.label_5.setFont(font) self.label_5.setObjectName("label_5") self.textEdit_5 = QtWidgets.QTextEdit(Dialog) self.textEdit_5.setGeometry(QtCore.QRect(10, 660, 181, 31)) self.textEdit_5.setObjectName("textEdit_5") self.label_6 = QtWidgets.QLabel(Dialog) self.label_6.setGeometry(QtCore.QRect(10, 710, 471, 31)) font = QtGui.QFont() font.setPointSize(14) self.label_6.setFont(font) self.label_6.setObjectName("label_6") self.textEdit_6 = QtWidgets.QTextEdit(Dialog) self.textEdit_6.setGeometry(QtCore.QRect(10, 750, 181, 31)) self.textEdit_6.setObjectName("textEdit_6") self.label_7 = QtWidgets.QLabel(Dialog) self.label_7.setGeometry(QtCore.QRect(10, 170, 251, 31)) font = QtGui.QFont() font.setPointSize(14) self.label_7.setFont(font) self.label_7.setObjectName("label_7") self.textEdit_7 = QtWidgets.QTextEdit(Dialog) self.textEdit_7.setGeometry(QtCore.QRect(10, 210, 181, 31)) self.textEdit_7.setObjectName("textEdit_7") self.label_8 = QtWidgets.QLabel(Dialog) self.label_8.setGeometry(QtCore.QRect(10, 20, 231, 31)) font = QtGui.QFont() font.setPointSize(14) self.label_8.setFont(font) self.label_8.setObjectName("label_8") self.textEdit_8 = QtWidgets.QTextEdit(Dialog) self.textEdit_8.setGeometry(QtCore.QRect(10, 60, 181, 31)) self.textEdit_8.setObjectName("textEdit_8") self.label_9 = QtWidgets.QLabel(Dialog) self.label_9.setGeometry(QtCore.QRect(10, 100, 241, 31)) font = QtGui.QFont() font.setPointSize(14) self.label_9.setFont(font) self.label_9.setObjectName("label_9") self.textEdit_9 = QtWidgets.QTextEdit(Dialog) self.textEdit_9.setGeometry(QtCore.QRect(10, 140, 181, 31)) self.textEdit_9.setObjectName("textEdit_9") self.comboBox = QtWidgets.QComboBox(Dialog) self.comboBox.setGeometry(QtCore.QRect(10, 290, 251, 41)) font = QtGui.QFont() font.setPointSize(14) self.comboBox.setFont(font) self.comboBox.setObjectName("comboBox") self.comboBox.addItem("") self.comboBox.addItem("") self.pushButton = QtWidgets.QPushButton(Dialog) self.pushButton.setGeometry(QtCore.QRect(610, 20, 371, 111)) font = QtGui.QFont() font.setPointSize(20) self.pushButton.setFont(font) self.pushButton.setObjectName("pushButton") self.retranslateUi(Dialog) QtCore.QMetaObject.connectSlotsByName(Dialog) def retranslateUi(self, Dialog): _translate = QtCore.QCoreApplication.translate Dialog.setWindowTitle(_translate("Dialog", "Dialog")) self.label.setText(_translate("Dialog", "Выбор нагрузки")) self.label_2.setText(_translate("Dialog", "Линейная скорость распространения пожара(м/мин)")) self.label_3.setText(_translate("Dialog", "Расчет времени обнаружения(мин)")) self.label_4.setText(_translate("Dialog", "Расчет времени следования(мин)")) self.label_5.setText(_translate("Dialog", "Расчет времени боевого развертывания(мин)")) self.label_6.setText(_translate("Dialog", "Скорость передвижения персонала(м/мин)")) self.label_7.setText(_translate("Dialog", "Высота помещения(м)")) self.label_8.setText(_translate("Dialog", "Длина помещения(м)")) self.label_9.setText(_translate("Dialog", "Ширина помещения(м)")) self.comboBox.setItemText(0, _translate("Dialog", "Склад льноволокна")) self.comboBox.setItemText(1, _translate("Dialog", "Верхняя одежда;ворс, ткани (шерсть+нейлон)")) self.pushButton.setText(_translate("Dialog", "Открыть 3d проект")) class MyInst(QtWidgets.QWidget): #2-Весь блок(Ошибка в том,что нельзя обращаться к файлу main напрямую,только к классу) def __init__(self, parent=None): super(main, self).__init__(parent) self.setupUi(self) class Main(QtWidgets.QWidget,Ui_Dialog): def __init__(self, parent=None): super(Main, self).__init__(parent) self.setupUi(self) self.pushButton.clicked.connect(self.onClicked) def onClicked(self): self.inst = MyInst() self.inst.show() #До этого момента включительно if __name__ == "__main__": import sys app = QtWidgets.QApplication(sys.argv) #Dialog = QtWidgets.QDialog() 3)Эти 4 строчки убираем # ui = Ui_Dialog() # ui.setupUi(Dialog) #Dialog.show() w=Main() #4) А эти 2 добавляем w.show() sys.exit(app.exec_())
ПроектГде:
Config
—-conf.ini
resources
module_sale
—-__init__.py
—-sale.py
—-sale_design.py
venv
main.py
mainform_design.py
resource_rc.py
import sys # sys нужен для передачи argv в QApplication from configparser import ConfigParser from PyQt5 import QtWidgets from PyQt5.QtWidgets import QLabel, QMessageBox, QProgressBar, QTableWidgetItem from PyQt5.QtGui import QPixmap, QIcon import mainform_design from module_sale import sale_design from module_sale import sale # Переменные глобальные conf: ConfigParser = ConfigParser() conf.read('config/conf.ini') folder = conf.get('Settings', 'Folder') filters = conf.get('Settings', 'Filter') sql_file = conf.get('Settings', 'SQL File') sum_ini = conf.get('Settings', 'Sum') limit = conf.get('Settings', 'Limit') conf_sum = ConfigParser() conf_sum.read(sum_ini) # Главный класс class MainForm(QtWidgets.QMainWindow, mainform_design.Ui_MainWindow): # Инициализация окна и обработчики событий def __init__(self): # Это здесь нужно для доступа к переменным, методам # и т.д. в файле design.py super().__init__() self.setupUi(self) self.sales = SaleDialogImport(self) self.start() self.btn_Shop.clicked.connect(self.sales.show_sale_dialog) # тут происходит вызов сторонней формы # Процедура отображения запроса при выходе с программы def closeEvent(self, event): reply = QMessageBox.question(self, 'Выход', "Как, уже уходите?", QMessageBox.Yes, QMessageBox.No) if reply == QMessageBox.Yes: event.accept() else: event.ignore() # Процедура, выполняющаяся при старте и устанавливающая контролам свойства def start(self): self.btn_Parce.setEnabled(False) self.btn_Finalize.setEnabled(False) self.btn_Save.setEnabled(False) self.tabs.setCurrentIndex(0) self.lbl_countline.hide() self.lbl_validline.hide() self.lbl_checked.hide() self.lbl_progres.hide() self.pr_progres.hide() class SaleDialogImport (QtWidgets.QMainWindow, sale_design.Ui_shop): def __init__(self, parent=None): super(SaleDialogImport, self).__init__(parent) self.setupUi(self) self.parent = parent self.sal = sale.SaleDialog() def show_sale_dialog(self): self.show() self.sal.filter_type() self.sal.yahr_sort() if __name__ == '__main__': app = QtWidgets.QApplication(sys.argv) window = MainForm() window.show() sys.exit(app.exec_())
y = 0 # Длинна генерируемого массива x = 0 # Для цыкла генерации m = [] # Генерируемый массив a = 0 # Количество символов j = 0 # Элемент массива j1 = 1 # Элемент массива e = 1 # Счетчик этераций v = '0123456789A' # Элементы для заполнения print ('Введите длинну генерируемых комбинаций: \n') y = int (input ()) st = len(v)**y print ('Количество возможных вариантов: ' + str(st)) # Генерируем массив while x < y: x += 1 m = m + ['0'] print (m) # Перебираем значения while j <= y: for i in v: # Перебираем элементы m[ - len(m) + j] = i for i in v: m[ - len(m) + j1] = i e += 1 print ('Этерация № ' + str(e) + str(m)) j1 += 1 j += 1