#!/usr/bin/python # -*- coding: utf-8 -*- # @version : 1.0 # @Create Time : 2022/10/9 17:09 # @File : tools.py # @IDE : PyCharm # @desc : 工具类 import datetime import random import re import string from typing import List, Union import importlib from core.logger import logger def test_password(password: str) -> Union[str, bool]: """ 检测密码强度 """ if len(password) < 8 or len(password) > 16: return '长度需为8-16个字符,请重新输入。' else: for i in password: if 0x4e00 <= ord(i) <= 0x9fa5 or ord(i) == 0x20: # Ox4e00等十六进制数分别为中文字符和空格的Unicode编码 return '不能使用空格、中文,请重新输入。' else: key = 0 key += 1 if bool(re.search(r'\d', password)) else 0 key += 1 if bool(re.search(r'[A-Za-z]', password)) else 0 key += 1 if bool(re.search(r"\W", password)) else 0 if key >= 2: return True else: return '至少含数字/字母/字符2种组合,请重新输入。' def list_dict_find(options: List[dict], key: str, value: any) -> Union[dict, None]: """ 字典列表查找 """ return next((item for item in options if item.get(key) == value), None) def get_time_interval(start_time: str, end_time: str, interval: int, time_format: str = "%H:%M:%S") -> List: """ 获取时间间隔 :param end_time: 结束时间 :param start_time: 开始时间 :param interval: 间隔时间(分) :param time_format: 字符串格式化,默认:%H:%M:%S """ if start_time.count(":") == 1: start_time = f"{start_time}:00" if end_time.count(":") == 1: end_time = f"{end_time}:00" start_time = datetime.datetime.strptime(start_time, "%H:%M:%S") end_time = datetime.datetime.strptime(end_time, "%H:%M:%S") time_range = [] while end_time > start_time: time_range.append(start_time.strftime(time_format)) start_time = start_time + datetime.timedelta(minutes=interval) return time_range def generate_string(length: int = 8) -> str: """ 生成随机字符串 :param length: 字符串长度 """ return ''.join(random.sample(string.ascii_letters + string.digits, length)) def import_modules(modules: list, desc: str, **kwargs): for module in modules: if not module: continue try: # 动态导入模块 module_pag = importlib.import_module(module[0:module.rindex(".")]) getattr(module_pag, module[module.rindex(".") + 1:])(**kwargs) except ModuleNotFoundError: logger.error(f"AttributeError:导入{desc}失败,未找到该模块:{module}") except AttributeError: logger.error(f"ModuleNotFoundError:导入{desc}失败,未找到该模块下的方法:{module}") async def import_modules_async(modules: list, desc: str, **kwargs): for module in modules: if not module: continue try: # 动态导入模块 module_pag = importlib.import_module(module[0:module.rindex(".")]) await getattr(module_pag, module[module.rindex(".") + 1:])(**kwargs) # except TimeoutError: # logger.error(f"asyncio.exceptions.TimeoutError:连接Mysql数据库超时") # print(f"asyncio.exceptions.TimeoutError:连接Mysql数据库超时") except ModuleNotFoundError: logger.error(f"AttributeError:导入{desc}失败,未找到该模块:{module}") except AttributeError: logger.error(f"ModuleNotFoundError:导入{desc}失败,未找到该模块下的方法:{module}")