Beispiel #1
0
def download(signals: pyqtSignal = None):
    url = WxConfig.getAppDownloadUrl()
    localpath = WxConfig.getAppexeReplaceDir()
    if localpath is None:
        localpath = FilePathUtil.get_full_dir('dist', 'window_main.exe')
    if os.path.exists(localpath):
        os.remove(localpath)
    downloadFile(localpath, url, signals)
    return FilePathUtil.get_full_dir('dist')
 def __init__(self):
     """
     初始化
     """
     # 驱动配置
     super().__init__()
     self.config = MonitorConfig()
     self.last_record_phone = self.config.get_value("wx_content",
                                                    "last_phone")
     self.max_count = int(WxConfig.get_add_friend_max_count())
     self.addfriend_inte_seconds = int(
         WxConfig.get_addfriend_inte_seconds())
Beispiel #3
0
    def __init__(self):
        self.total_count = 0
        self.desired_caps = WxConfig.getAppiumConfig()
        try:
            self.driver = webdriver.Remote(WxConfig.getServerUrl(), self.desired_caps)
            self.wait = WebDriverWait(self.driver, TIMEOUT)
            x = self.driver.get_window_size()['width']
            y = self.driver.get_window_size()['height']
            self.screen_size = [x, y]
            self.by = mobileby.MobileBy()
        except Exception as e:
            print(f"{e}")
            pass

        pass
Beispiel #4
0
 def main(self):
     sleep(self.get_sleep(6, 10))
     # 点击搜索按钮
     self.find_element_by_id('com.tencent.mm:id/f8y').click()
     sleep(self.get_sleep(3, 5))
     # full_dir = FilePathUtil.get_full_dir("wxfriend", "excel", "手机号列表.xls")
     full_dir = WxConfig.getPhoneExcel()
     if not full_dir:
         Logger.println(f"【main(请先配置手机号列表文件】")
         return
     array = excel_util.excel2array(full_dir)
     length = len(array)
     if not array:
         Logger.println(f"【main(请先配置手机号列表文件的sheet_name为手机号列表】")
         return
     # array = [{'手机': '18612205027'}]
     # array = [{'手机': '18612205027'}, {'手机': '15821902923'}]
     start_index = 0
     for index, element in enumerate(array):
         if str(int(element["手机"])) == self.last_record_phone:
             start_index = index
             Logger.println(
                 f"【main找到上次添加的手机位置={start_index + 1}={self.last_record_phone}】"
             )
             break
     count = 0
     if start_index + 1 > length:
         Logger.println(f"【已经是最后一条了】")
         return
     for index, item in enumerate(array[start_index + 1:length]):
         if wx_stop.stopFlag:
             break
         phone = str(int(item['手机']))
         Logger.println(f"【main({index}).开始添加手机={phone}】")
         Logger.println(f"【main开始执行第{count}个任务】")
         if self.max_count > 1 and count > 1 and (count %
                                                  self.max_count) == 0:
             start_time = int(time())
             sleeptime = self.addfriend_inte_seconds
             Logger.println(
                 f"【main(暂时停止任务开启休闲模式).{sleeptime}秒后执行第={count}个任务】")
             while True:
                 rdsleep = self.get_sleep(5, 6)
                 by_id = self.find_element_by_id('com.tencent.mm:id/bhn')
                 if rdsleep == 5:
                     if by_id:
                         by_id.send_keys(f'已经休眠{int(time()) - start_time}s')
                 else:
                     if by_id:
                         by_id.send_keys('')
                 sleep(rdsleep)
                 if int(time()) - start_time > sleeptime:
                     break
             Logger.println(f"【main(退出休闲模式)继续执行第={count}个任务】")
         if wx_stop.stopFlag:
             break
         if self.add(phone):
             break
         count += 1
         Logger.println(f"【main(花费时间).total_count={self.total_count}s】")
Beispiel #5
0
def download_resources():
    url = WxConfig.getAppDownloadUrl()
    download_address = FilePathUtil.get_full_dir('dist', 'window_main_resources.zip')
    if os.path.exists(download_address):
        os.remove(download_address)
    downloadFile(download_address, url)
    return FilePathUtil.get_full_dir('dist')
Beispiel #6
0
    def reconnect(self):
        config = WxConfig.getAppiumConfig()
        deviceId = config["deviceName"]
        platformVersion = config["platformVersion"]

        self.le0.setText(deviceId)
        self.le1.setText(platformVersion)
Beispiel #7
0
def deletePictures():
    Logger.println(
        f"【deletePictures===========开始删除手机图片缓存========================】")
    deviceId = WxConfig.getAppiumConfig()["deviceName"]
    if deviceId:
        execute_adb_shell('shell rm -r /sdcard/Pictures/WeiXin',
                          deviceId=deviceId)
    Logger.println(f"【deletePictures===========删除图片缓存执行完成=================】")
Beispiel #8
0
def export():
    full_dir = FilePathUtil.get_full_dir('wxfriend', 'pic')
    weixinPath = FilePathUtil.get_full_dir('wxfriend', 'pic', 'WeiXin')
    if os.path.exists(weixinPath):
        try:
            shutil.rmtree(weixinPath)
        except:
            pass
    deviceId = WxConfig.getAppiumConfig()["deviceName"]
    if deviceId:
        execute_adb_shell(f'pull /sdcard/Pictures/WeiXin/ {full_dir}',
                          deviceId=deviceId)
    else:
        Logger.println(f"【().未找到设备】")
Beispiel #9
0
 def crawl(self):
     self.config = MonitorConfig()
     self.wx_content_md5 = self.config.get_value("wx_content", "md5_pic")
     self.md5_contents = []
     self.enter()
     """
     爬取
     :return:
     """
     index = 0
     isFirst = True
     contents = []
     lastItem = None
     while True:
         self.crawl_max_count = int(WxConfig.get_crawl_max_count())
         if index % self.crawl_max_count == 0:
             self.md5_contents.clear()
             Logger.println(
                 f"【======={index},抓取数退出{self.crawl_max_count},本轮抓取已完成,开始滑动到顶部下拉刷新继续==========】"
             )
             self.swipe_to_top()
         if wx_stop.stopFlag:
             break
         # 上滑
         if not isFirst:
             self.swipe_up_slow()
         isFirst = False
         top_element = self.wait_find_element(
             By.XPATH, '//android.support.v7.widget.LinearLayoutCompat')
         if lastItem and top_element:
             self.scrollElement(lastItem, top_element)
         sleep(3)
         items = self.wait_find_elements(
             By.XPATH,
             '//android.widget.ListView/android.widget.RelativeLayout')
         if items is None:
             Logger.println(f"【============未获取到列表================】")
             continue
         for item in items:
             accessibility_id = self.find_element_by_accessibility_id(
                 '头像', item)
             if accessibility_id:
                 lastItem = item
             b_e_content = None
             last_pic_md5 = None
             last_md5_ = None
             advise = self.find_element_by_xpath(
                 "//android.widget.TextView[contains(@text,'广告')]", item)
             if advise:
                 Logger.println(
                     f"【============检测到广告忽略进入下一条================】")
                 continue
             message_text_container = self.config.get_value(
                 "wx_content_ids", "message_text_container")
             content_element = self.find_element_by_id(
                 message_text_container, item)
             if content_element:
                 content_element.click()
                 b_e_content = self.waitContentTextById(
                     "com.tencent.mm:id/fpu")
                 if b_e_content:
                     Logger.println(f"【获取到详情页面全文内容={b_e_content}】")
                     self.go_back()
             if b_e_content is None:
                 message_text = self.config.get_value(
                     "wx_content_ids", "message_text")
                 b_e_content = self.getContentTextById(message_text, item)
             if b_e_content is None:
                 Logger.println(f"【============该条说说没有文本,忽略===========】")
                 continue
             nickName = self.getNickName(item)
             phone = self.get_phone_from_txt(b_e_content)
             md5_ = self.MD5(b_e_content)
             if len(b_e_content) > 3 and b_e_content[-3:] == '...':
                 elment_datas = self.scan_all_text_elment(item)
                 LogUtil.info_jsonformat(elment_datas)
             contition = (last_md5_ in self.wx_content_md5) and (
                 md5_ in self.wx_content_md5
             ) if last_md5_ else md5_ in self.wx_content_md5
             if contition:
                 Logger.println(
                     f"【crawl{index}已经抓取到上一次位置md5_=({md5_},last_md5_={last_md5_}).data={b_e_content}】"
                 )
                 md5 = None
                 if len(self.md5_contents) > 1:
                     md5 = ','.join(self.md5_contents[0:2])
                 elif len(self.md5_contents) > 0:
                     md5 = self.md5_contents[0]
                 if md5:
                     self.config.set_value("wx_content", "md5_pic", md5)
                 Logger.println(f"【============开始滑动到顶部===========】")
                 Logger.dingdingException(f"本轮抓取已完成,开始滑动到顶部下拉刷新继续")
                 self.swipe_to_top()
                 break
             if md5_ in self.today_md5_contents:
                 last_md5_ = md5_
                 Logger.println(f"【============该条说说已经抓取过,忽略===========】")
                 continue
             image0 = self.find_element_by_xpath("//*[@content-desc='图片']",
                                                 item)
             if image0:
                 Logger.println(f"【crawl({index}).开始点击图片】")
                 image0.click()
                 sleep(2)
                 start = '0'
                 end = '0'
                 for index_img in range(9):
                     image_detail = self.find_element_by_id(
                         'com.tencent.mm:id/c9h')
                     if image_detail:
                         text_content = self.wait_find_element(
                             By.XPATH, "//*[contains(@content-desc,'当前')]"
                         ).get_attribute('content-desc')
                         Logger.println(
                             f"【crawl.{index} text_content ={text_content}】"
                         )
                         pic_md5 = self.MD5(text_content)
                         if last_pic_md5 == pic_md5:
                             Logger.println(
                                 f"【crawl({index}.{index_img}).前后图片一致退出】")
                             if not end:
                                 sleep(2)
                                 end = time_util.get_time()
                             data = {
                                 'content_md5': md5_,
                                 'nick_name': nickName,
                                 'wx_number': "",
                                 'content': b_e_content,
                                 'phone': phone,
                                 'start': start,
                                 'end': end,
                                 'crawl_time': time_util.now_to_date(),
                                 'count': str(index_img)
                             }
                             if start != '0':
                                 contents.append(data)
                                 self.md5_contents.append(md5_)
                                 self.today_md5_contents.append(md5_)
                                 last_md5_ = md5_
                             self.go_back()
                             break
                         try:
                             action1 = TouchAction(self.driver)
                             action1.long_press(el=image_detail,
                                                duration=500).perform()
                             saveBtn = self.wait_find_element(
                                 By.XPATH, "//*[contains(@text,'保存图片')]")
                             if saveBtn:
                                 saveBtn.click()
                                 element = self.wait_find_element(
                                     By.XPATH,
                                     "//*[contains(@text,'图片已保存')]")
                                 attribute = element.get_attribute('text')
                                 Logger.println(
                                     f"【crawl.{index} text_content ={attribute}】"
                                 )
                                 if attribute and ".jpg" in attribute:
                                     if index_img == 0:
                                         start = get_time_from_text(
                                             attribute)
                                     end = get_time_from_text(attribute)
                             else:
                                 Logger.dingdingException(f"找不到保存按钮,保存图片失败")
                         except Exception as e:
                             Logger.dingdingException(f"保存图片失败{e}")
                             Logger.println(f'保存图片失败 Exception{e}')
                             self.go_back()
                             continue
                         last_pic_md5 = pic_md5
                         if index_img == 8:
                             if not end:
                                 sleep(2)
                                 end = time_util.get_time()
                             data = {
                                 'content_md5': md5_,
                                 'nick_name': nickName,
                                 'wx_number': "",
                                 'content': b_e_content,
                                 'phone': phone,
                                 'start': start,
                                 'end': end,
                                 'crawl_time': time_util.now_to_date(),
                                 'count': str(index_img + 1)
                             }
                             if start != '0':
                                 Logger.println(
                                     f"【crawl({index}.{index_img}).已保存图片=mmexport{end}.jpg】"
                                 )
                                 contents.append(data)
                                 self.md5_contents.append(md5_)
                                 self.today_md5_contents.append(md5_)
                                 last_md5_ = md5_
                             self.go_back()
                             break
                         self.swipeLeft()
             else:
                 # 纯文本
                 data = {
                     'content_md5': md5_,
                     'nick_name': nickName,
                     'wx_number': "",
                     'content': b_e_content,
                     'phone': phone,
                     'start': "0",
                     'end': "0",
                     'crawl_time': time_util.now_to_date(),
                     'count': "0"
                 }
                 contents.append(data)
             if len(contents) > 0:
                 value = self.config.get_value("wx_content", "select")
                 if value == 'True':
                     Logger.println(f"开始上传第{index}条数据")
                     res = WxUploader.uploadItems(contents)
                     # 有房源刷新的列表
                     if '20003' == res:
                         contents[0]['content'] = ""
                         date = time_util.now_to_date('%Y%m%d')
                         full_dir = FilePathUtil.get_full_dir(
                             "wxfriend", "excel", "text",
                             date + "wx_pic_update_moments.xls")
                         excel_util.write_excel_append(filename=full_dir,
                                                       worksheet_name=date,
                                                       items=contents)
                         contents.clear()
                 # 新房源列表
                 if len(contents) > 0:
                     contents[0]['content'] = ""
                     date = time_util.now_to_date('%Y%m%d')
                     full_dir = FilePathUtil.get_full_dir(
                         "wxfriend", "excel", "pic",
                         date + "wx_pic_moments.xls")
                     excel_util.write_excel_append(filename=full_dir,
                                                   worksheet_name=date,
                                                   items=contents)
                     contents.clear()
                     index += 1
             else:
                 Logger.println(f"【没有数据不处理】")
             md5 = None
             if len(self.md5_contents) > 1:
                 md5 = ','.join(self.md5_contents[0:2])
             elif len(self.md5_contents) > 0:
                 md5 = self.md5_contents[0]
             if md5:
                 self.config.set_value("wx_content", "md5_pic", md5)
Beispiel #10
0
    def init_ui(self):
        self.setMinimumSize(960, 760)
        self.main_widget = QtWidgets.QWidget()  # 创建窗口主部件
        self.main_layout = QtWidgets.QGridLayout()  # 创建主部件的网格布局
        self.main_widget.setLayout(self.main_layout)  # 设置窗口主部件布局为网格布局
        self.config = MonitorConfig()
        # 配置服务器地址
        configAction = QAction(QIcon('exit.png'), '配置', self)
        configAction.setShortcut('Ctrl+Alt+S')
        configAction.setStatusTip('配置')
        configAction.triggered.connect(self.editConfigDialog)
        # 配置服务器地址
        picAction = QAction(QIcon('exit.png'), '打开图片文件夹', self)
        picAction.setShortcut('Ctrl+O')
        picAction.setStatusTip('图片文件夹')
        picAction.triggered.connect(self.openPicDir)

        downloadAction = QAction(QIcon('exit.png'), '下载最新版本', self)
        downloadAction.setStatusTip('下载最新版本')
        downloadAction.triggered.connect(self.download)

        # exportAction = QAction(QIcon('exit.png'), '从"描述"字段中提取手机号', self)
        # exportAction.setStatusTip('从"描述"字段中提取手机号')
        # exportAction.triggered.connect(self.exportPhone)

        # 底部状态栏
        self.statusBar().showMessage('状态栏')

        # 顶部菜单栏
        menubar = self.menuBar()
        menubar.setNativeMenuBar(False)
        fileMenu = menubar.addMenu('配置')
        fileMenu.addAction(configAction)
        # exMenu = menubar.addMenu('提取手机号')
        # exMenu.addAction(exportAction)
        picMenu = menubar.addMenu('打开图片文件夹')
        picMenu.addAction(picAction)
        downloadMenu = menubar.addMenu('版本更新')
        downloadMenu.addAction(downloadAction)

        openAction = QAction(QIcon(IconConfig.SETTING_DIR), '打开手机号配置目录', self)
        openAction.setShortcut('Ctrl+O')
        openAction.triggered.connect(self.openPhoneDir)
        self.toolbar = self.addToolBar('打开手机号配置目录')
        self.toolbar.addAction(openAction)

        self.left_widget = QtWidgets.QWidget()  # 创建左侧部件
        self.left_widget.setObjectName('left_widget')
        self.left_layout = QtWidgets.QGridLayout()  # 创建左侧部件的网格布局层
        self.left_widget.setLayout(self.left_layout)  # 设置左侧部件布局为网格

        self.right_widget = QtWidgets.QWidget()  # 创建右侧部件
        self.right_widget.setObjectName('right_widget')
        self.right_layout = QtWidgets.QGridLayout()
        self.right_widget.setLayout(self.right_layout)  # 设置右侧部件布局为网格

        self.main_layout.addWidget(self.left_widget, 0, 0, 3,
                                   2)  # 左侧部件在第0行第0列,占8行3列
        self.main_layout.addWidget(self.right_widget, 0, 2, 12,
                                   10)  # 右侧部件在第0行第3列,占8行9列
        self.setCentralWidget(self.main_widget)  # 设置窗口主部件

        models = [
            {
                'label': '导出微信通讯录',
                'objName': 'left_label'
            },
            {
                'label': '批量添加好友',
                'objName': 'left_label'
            },
            {
                'label': '批量修改备注为手机号',
                'objName': 'left_label'
            },
            {
                'label': '导出朋友圈信息',
                'objName': 'left_label'
            },
            {
                'label': '导出含文本朋友圈信息',
                'objName': 'left_label'
            },
            {
                'label': '导出图片到电脑',
                'objName': 'left_label'
            },
            {
                'label': '按文本内容对图片分组',
                'objName': 'left_label'
            },
            {
                'label': '上传文本到后台',
                'objName': 'left_label'
            },
            {
                'label': '上传图片到后台',
                'objName': 'left_label'
            },
            {
                'label': '开启导出图片并上传任务',
                'objName': 'left_label'
            },
            {
                'label': '恢复输入法',
                'objName': 'left_label'
            },
            {
                'label': '删除手机图片缓存',
                'objName': 'left_label'
            },
            {
                'label': '抓取当天遗漏数据',
                'objName': 'left_label'
            },
            {
                'label': '停止任务',
                'objName': 'left_label'
            },
        ]

        self.buttons = []
        for index, model in enumerate(models):
            btn = QtWidgets.QPushButton(model['label'])
            btn.setObjectName(model['objName'])
            self.buttons.append(btn)

        for index, btn in enumerate(self.buttons):
            self.left_layout.addWidget(btn, index, 0, 1, 3)
            if index == 0:
                btn.clicked.connect(self.clickGetContacts)
            elif index == 1:
                btn.clicked.connect(self.clickAddFriend)
            elif index == 2:
                btn.clicked.connect(self.clickModifyName)
            elif index == 3:
                btn.clicked.connect(self.clickTextWithPicMoment)
            elif index == 4:
                btn.clicked.connect(self.clickTextMoment)
            elif index == 5:
                btn.clicked.connect(self.clickExportPic)
            elif index == 6:
                btn.clicked.connect(self.clickPicClassfy)
            elif index == 7:
                btn.clicked.connect(self.clickUploadText)
            elif index == 8:
                btn.clicked.connect(self.clickUploadPic)
            elif index == 9:
                btn.clicked.connect(self.clickBatchUploadLabel)
            elif index == 10:
                btn.clicked.connect(self.clickKeyboardLabel)
            elif index == 11:
                btn.clicked.connect(self.clickClearPics)
            elif index == 12:
                btn.clicked.connect(self.clickGetLostLabel)
            elif index == 13:
                btn.clicked.connect(self.clickStopLabel)
        self.left_widget.setStyleSheet('''
            QPushButton#left_label{
                padding:10px;
                font-family: "Arial","Microsoft YaHei","黑体","宋体",sans-serif;
            }
        ''')
        self.right_widget.setStyleSheet('''
            QTextEdit#right_label{
                font-family: "Arial","Microsoft YaHei","黑体","宋体",sans-serif;
            }
        ''')

        self.runthread = Runthread(EventConst.WX_CONTACT)
        self.runthread0 = Runthread(EventConst.MAIN_BULK_ADDFRIEND)
        self.runthread01 = Runthread(EventConst.MAIN_BULK_M_NAME)
        self.runthread1 = Runthread(EventConst.WX_MAIN_PIC)
        self.runthread2 = Runthread(EventConst.WX_MAIN)
        self.runthread3 = Runthread(EventConst.WX_EXPORT)
        self.runthread31 = Runthread(EventConst.WX_PICCLASSFY)
        self.runthread4 = Runthread(EventConst.WX_UPLOADER)
        self.runthread5 = Runthread(EventConst.WX_PICUPLOADER)
        self.runthread6 = Runthread(EventConst.WX_EXPORT_PHONE)
        self.runthread7 = Runthread(EventConst.WX_BATCH_UPLOAD)
        self.runthread8 = Runthread(EventConst.WX_CLEAR_PIC)
        self.runthread9 = Runthread(EventConst.WX_GET_LOST_PIC)
        self.stopRunner = StopRunthread()
        self.boardRunthread = KeyBoardRunthread()
        self.runthread.signals.connect(self.call_backlog)
        self.runthread0.signals.connect(self.call_backlog)
        self.runthread01.signals.connect(self.call_backlog)
        self.runthread1.signals.connect(self.call_backlog)
        self.runthread2.signals.connect(self.call_backlog)
        self.runthread3.signals.connect(self.call_backlog)
        self.runthread31.signals.connect(self.call_backlog)
        self.runthread4.signals.connect(self.call_backlog)
        self.runthread5.signals.connect(self.call_backlog)
        self.runthread6.signals.connect(self.call_backlog)
        self.runthread7.signals.connect(self.call_backlog)
        self.runthread8.signals.connect(self.call_backlog)
        self.runthread9.signals.connect(self.call_backlog)
        self.stopRunner.signals.connect(self.call_backlog)
        self.boardRunthread.signals.connect(self.call_backlog)

        self.right_label = QtWidgets.QTextEdit("")
        self.right_label.setPlaceholderText("日志输出区")
        self.right_label.setObjectName('right_label')
        self.right_layout.addWidget(self.right_label, 0, 0, 1, 3)
        # self.setWindowOpacity(0.9)  # 设置窗口透明度
        self.setWindowTitle('屋聚科技自动化运营工具V2.1')
        self.setWindowIcon(QIcon(IconConfig.LOGO_DIR))
        # self.setAttribute(QtCore.Qt.WA_TranslucentBackground)  # 设置窗口背景透明
        # self.setWindowFlag(QtCore.Qt.FramelessWindowHint)  # 隐藏边框
        self.main_layout.setSpacing(0)
        excel = WxConfig.getPhoneExcel()
        if excel:
            self.statusBar().showMessage(f'手机号文件地址:{excel}')
        else:
            self.statusBar().showMessage(f'请先点击配置菜单配置数据')

        value = self.config.get_value("wx_content", "select")
        if value == 'True':
            self.buttons[7].setEnabled(False)
        else:
            self.buttons[7].setEnabled(True)
Beispiel #11
0
 def add_phone_excel(self):
     full_dir = FilePathUtil.get_full_dir("wxfriend", "excel")
     filepath = self.open_file(full_dir)
     if filepath:
         WxConfig.setPhoneExcel(filepath)
         self.le4.setText(filepath)
Beispiel #12
0
    def __init__(self, parent=None):
        super(ConfigDialog, self).__init__(parent)
        layout = QFormLayout()
        self.config = MonitorConfig()

        self.label = QLabel("已连接设备名称:")
        self.le0 = QLineEdit()
        deviceId = WxConfig.getAppiumConfig()["deviceName"]
        self.le0.setPlaceholderText("未检测到设备")
        self.le0.setText(deviceId)
        layout.addRow(self.label, self.le0)
        self.label = QLabel("已连接安卓版本:")
        self.le1 = QLineEdit()
        platformVersion = WxConfig.getAppiumConfig()["platformVersion"]
        self.le1.setPlaceholderText("未检测到版本")
        self.le1.setText(platformVersion)
        layout.addRow(self.label, self.le1)

        self.label = QLabel("服务器地址:")
        self.le2 = QLineEdit()
        url = WxConfig.getServerUrl()
        self.le2.setText(url)
        layout.addRow(self.label, self.le2)

        self.label = QLabel("最大添加好友上限(人数):")
        self.le3 = QLineEdit()
        add_friend_max_count = WxConfig.get_add_friend_max_count()
        self.le3.setText(add_friend_max_count)
        layout.addRow(self.label, self.le3)

        self.label = QLabel("任务暂停后继续执行的时间间隔(秒):")
        self.le31 = QLineEdit()
        max_count = WxConfig.get_addfriend_inte_seconds()
        self.le31.setText(max_count)
        layout.addRow(self.label, self.le31)

        self.label = QLabel("每次抓取任务上线数量(条):")
        self.le32 = QLineEdit()
        crawl_max_count = WxConfig.get_crawl_max_count()
        self.le32.setText(crawl_max_count)
        layout.addRow(self.label, self.le32)

        self.label = QLabel("批量导出图片上传脚本时间间隔(秒):")
        self.le41 = QLineEdit()
        batch_pic_seconds = self.config.get_value('appiumConfig',
                                                  'batch_pic_seconds')
        self.le41.setText(batch_pic_seconds)
        layout.addRow(self.label, self.le41)

        self.addbtn = QPushButton("设置手机号文件地址")
        self.addbtn.clicked.connect(
            self.add_phone_excel)  # 当点击save按钮时,对话框将会消失,点击Cacel按钮时,则不会消失。
        self.le4 = QLineEdit()
        phone_excel = WxConfig.getPhoneExcel()
        self.le4.setText(phone_excel)
        layout.addRow(self.addbtn, self.le4)

        self.label5 = QLabel("最新朋友圈图片md5值")
        self.le5 = QLineEdit()
        self.config = MonitorConfig()
        md5_pic = self.config.get_value("wx_content", "md5_pic")
        self.le5.setText(md5_pic)
        layout.addRow(self.label5, self.le5)

        self.label6 = QLabel("最新朋友圈文本md5值")
        self.le6 = QLineEdit()
        self.config = MonitorConfig()
        md5 = self.config.get_value("wx_content", "md5")
        self.le6.setText(md5)
        layout.addRow(self.label6, self.le6)

        self.label7 = QLabel("抓取文本时同时同步到云端")
        self.select_checkbox = QCheckBox("")
        value = self.config.get_value("wx_content", "select")
        if value == 'True':
            self.select_checkbox.setChecked(True)
        else:
            self.select_checkbox.setChecked(False)

        layout.addRow(self.label7, self.select_checkbox)
        self.label8 = QLabel("是否输出日志")
        self.log_checkbox = QCheckBox("")
        if Logger.debug:
            self.log_checkbox.setChecked(True)
        else:
            self.log_checkbox.setChecked(False)
        layout.addRow(self.label8, self.log_checkbox)

        self.cacelButton = QPushButton("重新检测")
        self.saveButton = QPushButton("保存")
        self.cacelButton.clicked.connect(
            self.reconnect)  # 当点击save按钮时,对话框将会消失,点击Cacel按钮时,则不会消失。
        self.saveButton.clicked.connect(
            self.save)  # 当点击save按钮时,对话框将会消失,点击Cacel按钮时,则不会消失。
        self.buttonBox = QDialogButtonBox(QtCore.Qt.Horizontal)
        self.buttonBox.addButton(self.saveButton, QDialogButtonBox.RejectRole)
        self.buttonBox.addButton(self.cacelButton, QDialogButtonBox.YesRole)
        layout.addRow(self.buttonBox)

        self.setLayout(layout)
        self.setWindowTitle("配置服务器地址")
        self.setWindowIcon(QIcon(IconConfig.LOGO_DIR))