Python3.7+PyQt5 pyuic5将.ui文件转换为.py文件、Python读取配置文件、生成日志

这篇具有很好参考价值的文章主要介绍了Python3.7+PyQt5 pyuic5将.ui文件转换为.py文件、Python读取配置文件、生成日志。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1.实际开发项目时,是使用Qt Designer来设计UI界面,得到一个.ui的文件,然后利用PyQt5安装时自带的工具pyuic5将.ui文件转换为.py文件:

pyuic5 -o mywindow.py mywindow.ui #先是py文件名,再是ui文件名

样式图 QT5 UI:

pyqt5导出py,python,qt,ui

转换的pyqt5:

# -*- coding: utf-8 -*-

# Form implementation generated from reading ui file 'ActionTools.ui'
#
# Created by: PyQt5 UI code generator 5.15.2
#
# WARNING: Any manual changes made to this file will be lost when pyuic5 is
# run again.  Do not edit this file unless you know what you are doing.
import socket

from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.Qt import *
import sys
import io
import os
import datetime
import random
from subprocess import Popen,PIPE
from threading import Thread
import time
import configparser

class Ui_ActionWinfrm(QWidget):
    def __init__(self):
        super(Ui_ActionWinfrm,self).__init__()
        self.config=configparser.ConfigParser()#创建对象
        self.EmployeeInfo=[]#员工信息
        self.TestServer=[]#测试服务器设置
        self.MesServer=[]#Mes服务器
        self.ProductInfo=[]#产品信息
        self.config.read("./conf/config.conf",encoding="utf-8")#读取配置文件,如果配置文件不存在创建
        self.Err="NULL"

        #员工管理信息
        self.EmployeeInfo.append(self.config.get('EmployeeInfo','Employee'))#工号
        self.EmployeeInfo.append(self.config.get('EmployeeInfo','Line'))#线体

        #测试服务器设置
        self.TestServer.append(self.config.get('TestServer','host'))
        self.TestServer.append(self.config.get('TestServer','prot'))
        self.TestServer.append(self.config.get('TestServer','user'))
        self.TestServer.append(self.config.get('TestServer','password'))

        #连接服务器
        self.host = self.TestServer[0]
        self.prot = self.TestServer[1]

        #MES服务器设置
        self.MesServer.append(self.config.get('MesServer','url'))

        #产品信息
        self.ProductInfo.append(self.config.get('ProductInfo','ClientName'))
        self.ProductInfo.append(self.config.get('ProductInfo','ProductName'))
        self.ProductInfo.append(self.config.get('ProductInfo','OrderInfo'))
        self.ProductInfo.append(self.config.get('ProductInfo','OrderTotal'))
        self.ProductInfo.append(self.config.get('ProductInfo','CompleteOrder'))

        self.data=''
        self.setupUi()
        print(self.host + "," + self.prot)
        self.Client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)


    def setupUi(self):
        self.setObjectName("ActionWinfrm")
        self.resize(1000, 943)
        font = QtGui.QFont()
        font.setFamily("Arial")
        font.setPointSize(12)
        self.setFont(font)
        icon = QtGui.QIcon()
        icon.addPixmap(QtGui.QPixmap("./Imag/020.ico"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
        self.setWindowIcon(icon)
        self.verticalLayout = QtWidgets.QVBoxLayout(self)
        self.verticalLayout.setObjectName("verticalLayout")
        self.frame_5 = QtWidgets.QFrame(self)
        self.frame_5.setFrameShape(QtWidgets.QFrame.StyledPanel)
        self.frame_5.setFrameShadow(QtWidgets.QFrame.Raised)
        self.frame_5.setObjectName("frame_5")
        self.frame_6 = QtWidgets.QFrame(self.frame_5)
        self.frame_6.setGeometry(QtCore.QRect(0, -1, 981, 41))
        self.frame_6.setStyleSheet("color: rgb(85, 255, 127);")
        self.frame_6.setFrameShape(QtWidgets.QFrame.StyledPanel)
        self.frame_6.setFrameShadow(QtWidgets.QFrame.Raised)
        self.frame_6.setObjectName("frame_6")
        self.lbl_WinTitle = QtWidgets.QLabel(self.frame_6)
        self.lbl_WinTitle.setGeometry(QtCore.QRect(390, 0, 351, 41))
        font = QtGui.QFont()
        font.setPointSize(26)
        self.lbl_WinTitle.setFont(font)
        self.lbl_WinTitle.setAlignment(QtCore.Qt.AlignCenter)
        self.lbl_WinTitle.setObjectName("lbl_WinTitle")
        self.lbl_loginfo = QtWidgets.QLabel(self.frame_6)
        self.lbl_loginfo.setGeometry(QtCore.QRect(10, 0, 161, 41))
        self.lbl_loginfo.setText("")
        self.lbl_loginfo.setPixmap(QtGui.QPixmap("./Imag/logo.jpg"))
        self.lbl_loginfo.setObjectName("lbl_loginfo")
        self.frame_7 = QtWidgets.QFrame(self.frame_5)
        self.frame_7.setGeometry(QtCore.QRect(0, 50, 981, 80))
        self.frame_7.setFrameShape(QtWidgets.QFrame.StyledPanel)
        self.frame_7.setFrameShadow(QtWidgets.QFrame.Raised)
        self.frame_7.setObjectName("frame_7")
        self.label = QtWidgets.QLabel(self.frame_7)
        self.label.setGeometry(QtCore.QRect(10, 10, 81, 16))
        self.label.setAlignment(QtCore.Qt.AlignCenter)
        self.label.setObjectName("label")
        self.label_3 = QtWidgets.QLabel(self.frame_7)
        self.label_3.setGeometry(QtCore.QRect(340, 10, 81, 16))
        self.label_3.setAlignment(QtCore.Qt.AlignCenter)
        self.label_3.setObjectName("label_3")
        self.label_4 = QtWidgets.QLabel(self.frame_7)
        self.label_4.setGeometry(QtCore.QRect(660, 10, 81, 16))
        self.label_4.setAlignment(QtCore.Qt.AlignCenter)
        self.label_4.setObjectName("label_4")
        self.label_2 = QtWidgets.QLabel(self.frame_7)
        self.label_2.setGeometry(QtCore.QRect(10, 50, 81, 16))
        self.label_2.setAlignment(QtCore.Qt.AlignCenter)
        self.label_2.setObjectName("label_2")
        self.label_5 = QtWidgets.QLabel(self.frame_7)
        self.label_5.setGeometry(QtCore.QRect(340, 50, 81, 16))
        self.label_5.setAlignment(QtCore.Qt.AlignCenter)
        self.label_5.setObjectName("label_5")
        self.label_6 = QtWidgets.QLabel(self.frame_7)
        self.label_6.setGeometry(QtCore.QRect(660, 50, 81, 16))
        self.label_6.setAlignment(QtCore.Qt.AlignCenter)
        self.label_6.setObjectName("label_6")
        self.label_7 = QtWidgets.QLabel(self.frame_7)
        self.label_7.setGeometry(QtCore.QRect(820, 50, 91, 20))
        self.label_7.setAlignment(QtCore.Qt.AlignCenter)
        self.label_7.setObjectName("label_7")
        self.lbl_ClientName = QtWidgets.QLabel(self.frame_7)
        self.lbl_ClientName.setGeometry(QtCore.QRect(100, 10, 151, 16))
        self.lbl_ClientName.setStyleSheet("color: rgb(255, 170, 0);")
        self.lbl_ClientName.setObjectName("lbl_ClientName")
        self.lbl_ProductName = QtWidgets.QLabel(self.frame_7)
        self.lbl_ProductName.setGeometry(QtCore.QRect(420, 10, 54, 12))
        self.lbl_ProductName.setStyleSheet("color: rgb(255, 170, 0);")
        self.lbl_ProductName.setObjectName("lbl_ProductName")
        self.lbl_OrderInfo = QtWidgets.QLabel(self.frame_7)
        self.lbl_OrderInfo.setGeometry(QtCore.QRect(730, 10, 101, 16))
        self.lbl_OrderInfo.setAutoFillBackground(False)
        self.lbl_OrderInfo.setStyleSheet("color: rgb(255, 170, 0);")
        self.lbl_OrderInfo.setObjectName("lbl_OrderInfo")
        self.lbl_Employee = QtWidgets.QLabel(self.frame_7)
        self.lbl_Employee.setGeometry(QtCore.QRect(90, 50, 91, 16))
        self.lbl_Employee.setStyleSheet("color: rgb(255, 170, 0);")
        self.lbl_Employee.setObjectName("lbl_Employee")
        self.lbl_Line = QtWidgets.QLabel(self.frame_7)
        self.lbl_Line.setGeometry(QtCore.QRect(420, 50, 81, 16))
        self.lbl_Line.setStyleSheet("color: rgb(255, 170, 0);")
        self.lbl_Line.setObjectName("lbl_Line")
        self.lbl_OrderTotal = QtWidgets.QLabel(self.frame_7)
        self.lbl_OrderTotal.setGeometry(QtCore.QRect(730, 50, 54, 12))
        self.lbl_OrderTotal.setStyleSheet("color: rgb(255, 170, 0);")
        self.lbl_OrderTotal.setObjectName("lbl_OrderTotal")
        self.lbl_COrderNum = QtWidgets.QLabel(self.frame_7)
        self.lbl_COrderNum.setGeometry(QtCore.QRect(910, 50, 54, 19))
        self.lbl_COrderNum.setStyleSheet("color: rgb(255, 170, 0);")
        self.lbl_COrderNum.setObjectName("lbl_COrderNum")
        self.textEdit = QtWidgets.QTextEdit(self.frame_5)
        self.textEdit.setGeometry(QtCore.QRect(0, 40, 981, 1))
        self.textEdit.setObjectName("textEdit")
        self.TW_TestItemList = QtWidgets.QTableWidget(self.frame_5)
        self.TW_TestItemList.setGeometry(QtCore.QRect(0, 180, 981, 631))
        font = QtGui.QFont()
        font.setPointSize(12)
        self.TW_TestItemList.setFont(font)
        self.TW_TestItemList.setSelectionBehavior(QtWidgets.QAbstractItemView.SelectRows)
        self.TW_TestItemList.setShowGrid(False)
        self.TW_TestItemList.setObjectName("TW_TestItemList")
        self.TW_TestItemList.setColumnCount(3)
        self.TW_TestItemList.setRowCount(0)
        self.item = QtWidgets.QTableWidgetItem()
        self.item.setTextAlignment(QtCore.Qt.AlignHCenter|QtCore.Qt.AlignTop)
        font = QtGui.QFont()
        font.setFamily("Arial")
        font.setPointSize(12)
        self.item.setFont(font)
        icon1 = QtGui.QIcon()
        icon1.addPixmap(QtGui.QPixmap("Imag/NewAdd.ico"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
        self.item.setIcon(icon1)
        self.TW_TestItemList.setHorizontalHeaderItem(0, self.item)
        self.item = QtWidgets.QTableWidgetItem()
        self.item.setTextAlignment(QtCore.Qt.AlignCenter)
        font = QtGui.QFont()
        font.setFamily("Arial")
        font.setPointSize(12)
        self.item.setFont(font)
        icon2 = QtGui.QIcon()
        icon2.addPixmap(QtGui.QPixmap("Imag/TestArgs.ico"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
        self.item.setIcon(icon2)
        self.TW_TestItemList.setHorizontalHeaderItem(1, self.item)
        self.item = QtWidgets.QTableWidgetItem()
        self.item.setTextAlignment(QtCore.Qt.AlignCenter)
        font = QtGui.QFont()
        font.setFamily("Arial")
        font.setPointSize(12)
        self.item.setFont(font)
        icon3 = QtGui.QIcon()
        icon3.addPixmap(QtGui.QPixmap("Imag/Result.ico"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
        self.item.setIcon(icon3)
        self.TW_TestItemList.setHorizontalHeaderItem(2, self.item)
        self.TW_TestItemList.horizontalHeader().setMinimumSectionSize(40)
        self.TW_TestItemList.verticalHeader().setDefaultSectionSize(50)
        self.TW_TestItemList.verticalHeader().setMinimumSectionSize(50)
        self.label_8 = QtWidgets.QLabel(self.frame_5)
        self.label_8.setGeometry(QtCore.QRect(10, 140, 112, 25))
        self.label_8.setObjectName("label_8")
        self.lbl_TestResult = QtWidgets.QLabel(self.frame_5)
        self.lbl_TestResult.setGeometry(QtCore.QRect(0, 815, 981, 111))
        self.lbl_TestResult.setStyleSheet("background-color: rgb(0, 0, 0);\n"
        "font: 22pt \"Arial\";\n"
        "color: rgb(255, 255, 0);")
        self.lbl_TestResult.setAlignment(QtCore.Qt.AlignCenter)
        self.lbl_TestResult.setObjectName("lbl_TestResult")
        self.lbl_Isn = QtWidgets.QLineEdit(self.frame_5)
        self.lbl_Isn.setGeometry(QtCore.QRect(130, 140, 800, 31))
        self.lbl_Isn.setObjectName("lbl_Isn")
        self.verticalLayout.addWidget(self.frame_5)
        self.retranslateUi()
        QtCore.QMetaObject.connectSlotsByName(self)
        self.setWindowFlags(QtCore.Qt.WindowMinimizeButtonHint | QtCore.Qt.WindowCloseButtonHint)  # 只显示最小化按钮和关闭按钮
        self.lbl_Isn.setFocus()

    def retranslateUi(self):
        self._translate = QtCore.QCoreApplication.translate
        self.setWindowTitle(self._translate("ActionWinfrm", "【T.e.s.t】"))
        self.lbl_WinTitle.setText(self._translate("ActionWinfrm", "国产系统在线激活工具"))
        self.label.setText(self._translate("ActionWinfrm", "客户名称:"))
        self.label_3.setText(self._translate("ActionWinfrm", "产品名称:"))
        self.label_4.setText(self._translate("ActionWinfrm", "订单号:"))
        self.label_2.setText(self._translate("ActionWinfrm", "员工工号:"))
        self.label_5.setText(self._translate("ActionWinfrm", "线          体:"))
        self.label_6.setText(self._translate("ActionWinfrm", "订单数:"))
        self.label_7.setText(self._translate("ActionWinfrm", "完成订单数:"))
        self.lbl_ClientName.setText(self.ProductInfo[0])#客户名称
        self.lbl_ProductName.setText(self.ProductInfo[1])#产品名称
        self.lbl_OrderInfo.setText(self.ProductInfo[2])#订单信息
        self.lbl_OrderTotal.setText(self.ProductInfo[3])#订单总数
        self.lbl_COrderNum.setText(self.ProductInfo[4])#完成订单数
        self.lbl_Employee.setText(self.EmployeeInfo[0])#工号
        self.lbl_Line.setText(self.EmployeeInfo[1])#线体
        self.item = self.TW_TestItemList.horizontalHeaderItem(0)
        self.item.setText(self._translate("ActionWinfrm", "项目名称"))
        self.item = self.TW_TestItemList.horizontalHeaderItem(1)
        self.item.setText(self._translate("ActionWinfrm", "测试参数"))
        self.item = self.TW_TestItemList.horizontalHeaderItem(2)
        self.item.setText(self._translate("ActionWinfrm", "测试结果"))
        self.TW_TestItemList.setColumnWidth(0,300)
        self.TW_TestItemList.setColumnWidth(1, 370)
        self.TW_TestItemList.setColumnWidth(2, 300)
        self.TW_TestItemList.setShowGrid(False)#是否显示网线
        self.label_8.setText(self._translate("ActionWinfrm", "扫描整机条码:"))
        self.lbl_TestResult.setText(self._translate("ActionWinfrm", "待测试"))

    def Center(self):#定义一个函数使得函数窗口居中显示
        #获取屏幕坐标系
        self.screen=QDesktopWidget().screenGeometry()
        #获取窗口坐标系
        self.size=self.geometry()
        self.newLeft=(self.screen.width()-self.size.width())/2
        self.newTop=(self.screen.height()-self.size.height())/2.7
        self.move(int(self.newLeft),int(self.newTop))

    def Connect(self,message):
        try:
            self.Client_socket.connect(self.host,int(self.port))
            self.lbl_TestResult.setText("Connected To Server..")
            self.lbl_TestResult.setForeground(QtGui.QColor(51, 204, 51))
            self.Client_socket.sendall(message.encode())
            self.data=self.Client_socket.recv(1024)
        except Exception as e:
            self.lbl_TestResult.setText("Connected To Server Err:"+str(e))
            self.lbl_TestResult.setStyleSheet("color:red")
            return False
        self.Client_socket.close()
        return True

if __name__ == '__main__':
    app = QApplication(sys.argv)
    win = Ui_ActionWinfrm()
    win.Center()
    win.show()
    #win.Client('10.2.230.10', 8888)
    win.Connect('tell me the product name and position:00E04C060621')
    sys.exit(app.exec_())

效果:

pyqt5导出py,python,qt,ui

2.Python学习之读取配置文件:

初始配置文件test.conf:

pyqt5导出py,python,qt,ui

步骤1:导入配置文件模块

import configparser

步骤2:创建配置文件对象

config = configparser.ConfigParser()

步骤3:读取配置文件
在这一步中,我们将读取配置文件。配置文件通常存储在.ini或.conf文件中。

config.read('config.ini')

步骤4:获取配置选项

option_value = config.get('section_name', 'option_name')

步骤5:修改配置选项

config.set('section_name', 'option_name', 'new_value')

步骤6:保存配置文件

with open('config.ini', 'w') as config_file:
    config.write(config_file)

*.展正读取confg的实列:

pyqt5导出py,python,qt,ui

3.生成日志:

1.创建日志记录器

import logging

# 创建一个日志记录器实例
logger = logging.getLogger('my_logger')

2 设置日志记录级别

logger.setLevel(logging.DEBUG)

使用setLevel()方法设置日志记录的级别,可以根据需要进行调整。常用的日志级别有:

logging.DEBUG:最详细的日志信息,用于调试程序。
logging.INFO:一般的日志信息,用于确认程序正常运行。
logging.WARNING:警告信息,表明程序可能出现问题。
logging.ERROR:错误信息,程序出现错误但仍然可以继续运行。
logging.CRITICAL:严重错误信息,程序无法继续运行。

3.创建文件处理器

file_handler = logging.FileHandler('log.txt')

4.设置文件处理器的格式

formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')
file_handler.setFormatter(formatter)

5.将处理器添加到记录器中

logger.addHandler(file_handler)

6.输出日志信息

logger.debug('This is a debug message')
logger.info('This is an info message')
logger.warning('This is a warning message')
logger.error('This is an error message')
logger.critical('This is a critical message')

pyqt5导出py,python,qt,ui文章来源地址https://www.toymoban.com/news/detail-822525.html

到了这里,关于Python3.7+PyQt5 pyuic5将.ui文件转换为.py文件、Python读取配置文件、生成日志的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Python - PyQT5 - ui文件转为py文件

    在QTdesigner图形化编辑工具中,有些控件我们是可以直接在编辑界面进行编辑的,有些是不可以编辑的,只能通过Python代码进行编辑,不过总体来说,所有能够通过图形化编辑界面可以编辑的,都可以通过Python语言实现控制,这点是毋庸置疑的,不过为了更加美观及降级软件开

    2024年02月05日
    浏览(52)
  • Python - PyQt6、QDesigner、pyuic5-tool 安装使用

    Python 开发可视化界面可以使用原生的 tkinter ,但是原生框架使用起来颇为不方便,所以最流行的还是 QT UI框架, QT 是使用 C++ 语言开发,Python 想使用需要对其进行封装,所以就出现了 PyQt 框架,这个框架使用极其方便,而且可以多端运行。 本人使用的是 Mac 2023款 Apple M1 芯片

    2024年02月09日
    浏览(39)
  • PyQt5 将.ui文件转为.py文件并用另一个.py调用

    值得注意的是,Anaconda Prompt不能直接cd进其它盘 需要在根目录下进行切换盘符操作,使用 cd ..切进上一级目录,直到进入根目录: 这样就可以了 代码说明 生成的py文件: 运行代码即可成功展示UI界面: 成功展示UI Anaconda Prompt切换路径不能进入D盘_软件安装好难啊的博客-CSD

    2024年02月16日
    浏览(63)
  • 树莓派(armv7l,arm32)buster配置Python虚拟环境、安装PyQt5、安装PySide2、ui和rc文件导出为py文件

    要从头设置好一台可用于开发的树莓派,可以参考树莓派 4B 无屏幕,连接WiFi、SSH、VNC,系统换源、pip换源,安装中文输入法 树莓派(或者说arm平台)使用Python虚拟环境的正确方式是使用 pipenv ,官网教程贴在这里pipenv-PyPi,建议先看懂,再进行树莓派的Python相关开发 PyQt5或者

    2024年01月20日
    浏览(44)
  • pyqt5超详细多进程界面设计及打包流程(UI框架建构、多线程打包、.ui.qrc文件的转.py)

    项目的目标是制作一个目标检测的UI界面,实现各类目标的实时检测。在制作的过程中真的遇到了数不清的坑,坑死人了。我自己梳理一下方便下次做项目还掉坑里,顺便给大伙避避坑,当然每个人遇到的情况不同,如果我遇到的问题恰好帮助你解决问题了那就太好啦。 在终

    2024年02月04日
    浏览(41)
  • pyqt5中.ui转为.py

    在PyQt中,可以使用Qt Designer创建GUI的图形界面,设计完成后可以将其保存为.ui文件。但是,这种文件不能直接用于Python代码编程,必须将其转换为Python脚本,才能在Python程序中使用该界面。 将.ui文件转换为.py文件可以让您的程序更加灵活和方便,因为.py文件中包含了用于构建

    2024年02月04日
    浏览(39)
  • python3GUI--仿win10任务管理器By:PyQt5(附UI源码)

    最近心血来潮想要做一款仿win10的任务管理器,练习一下基本布局和QChart的使用,实现任务管理、图表查看等功能,撰写本篇播客记录一下开发过程中的一些心得与体会,能给读者提供一些思路。软件打包好,放在了文末。 1.进程 详细信息表格支持按表头排序,点击表头会自

    2024年02月15日
    浏览(55)
  • PYQT5 ui转py后的调用

    将程序按文件夹分好类,检查时更加清晰如先建立resource文件夹,内部含images(存放图片)、UI(存放UI文件),resource文件夹与main等设计界面程序并列,ui转成py时放在resource文件夹下边。  login_pane.py(将转换好的login.py引用,在此处对界面进行设计) 将做好的界面类引到主界面

    2024年02月06日
    浏览(75)
  • mac python3.9安装pyqt5、qt5、pyqt5-tools

    pyqt6安装参考 PyQT6:看这一篇就够了 python PyQt6 常用操作以及常见问题解决 pycharm配置tools 参考链接 以下pip命令自行更具自己环境选择pip或pip3 在安装pyqt前必须先安装sip包 完成sip的安装后,安装pyqt和pyqt-tools, 可以直接使用命令: 若是使用pip3安装报错 AttributeError: module ‘sipb

    2024年02月14日
    浏览(46)
  • 为PyCharm IDE 配置三剑客:QtDesigner[可视化设计器]、PyUIC[可视化设计器ui文件转py代码]、PyRcc[资源文件转py代码]

    过去一直在使用Eric6 + PyQt5,然而最近它[已然是古董级的了]似乎有些不太正常,  像我这样有强迫症的人怎么可以容忍呢? 于是有了换IDE的想法,听说PyCharm是个高富帅,大家都很喜欢用它呢!于是乎才有了这篇文章。 前提条件是: 1.已安装Python环境,版本随意【话说2023年了

    2024年02月12日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包