前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >python 自动登录 脚本

python 自动登录 脚本

作者头像
用户5760343
发布2022-05-13 10:11:13
1.2K0
发布2022-05-13 10:11:13
举报
文章被收录于专栏:sktj

-- coding: utf-8 --

import tesserocr from PIL import Image from selenium import webdriver import time import sys import datetime import os import csv import re from win32com.client import Dispatch, DispatchEx import pythoncom from PIL import ImageGrab, Image import uuid import configparser

def yzm(path): ima = Image.open(path) image=ima.resize((480,200),Image.ANTIALIAS) image = image.convert('L')

这个是二值化阈值

threshold = 160 table = [] for i in range(256): if i < threshold: table.append(0) else: table.append(1)

通过表格转换成二进制图片,1的作用是白色,不然就全部黑色了

image = image.point(table, "1") return tesserocr.image_to_text(image)[:5] # print ocr text from image def dl(browser,username,password): un = browser.find_element_by_id("username") un.clear() un.send_keys(username) pw = browser.find_element_by_id("password") pw.clear() pw.send_keys(password) time.sleep(1) if os.path.exists("Login_page.png"): os.remove("Login_page.png") if os.path.exists("Verification.png"): os.remove("Verification.png") browser.save_screenshot('Login_page.png') img=browser.find_element_by_id("jcaptchaImage") left = img.location['x'] top = img.location['y'] right = img.location['x'] + img.size['width'] bottom = img.location['y'] + img.size['height'] photo = Image.open('Login_page.png') box=(left,top,right,bottom) photo.crop(box).save('Verification.png') yz = browser.find_element_by_id("jcaptcha") yzmmmmm = yzm("Verification.png") print(yzmmmmm) yz.send_keys(yzmmmmm) time.sleep(1) lg = browser.find_element_by_id("login-btn") lg.click() time.sleep(1) try: err = browser.find_element_by_class_name("err-vaild") return err.text.strip() except: return None

def main(): conf = configparser.ConfigParser() conf.read("pmsrep.ini") fndir=conf.get("main","fndir")

from_addr = conf.get("email","from_addr") password =conf.get("email","password") to_addr =conf.get("email","to_addr") cc_addr=conf.get("email","cc_addr") smtp_server = "mail.wangsu.com"

username=conf.get("login","username") password=conf.get("login","password") loginnum = int(conf.get("login", "loginnum"))

chromedriver = "chromedriver.exe" options=webdriver.ChromeOptions() options.add_argument('--ignore-certificate-errors') browser = webdriver.Chrome(chromedriver,chrome_options=options) # Get local session of firefox browser.maximize_window() browser.get("https://portal.chinanetcenter.com/cas/login?service=https%3A%2F%2Fsi.chinanetcenter.com%2Fr_sec_login&appcode=serviceinsight") err=dl(browser,username,password) i=0 while err!=None and i<loginnum: i+=1 err = dl(browser,username, password) if err!=None: #send_text(from_addr,password,"无法登录,用户名或密码或验证码错误!需要重新执行程序.") sys.exit()

main()

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-05-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • -- coding: utf-8 --
  • 这个是二值化阈值
  • 通过表格转换成二进制图片,1的作用是白色,不然就全部黑色了
相关产品与服务
AI 应用产品
文字识别(Optical Character Recognition,OCR)基于腾讯优图实验室的深度学习技术,将图片上的文字内容,智能识别成为可编辑的文本。OCR 支持身份证、名片等卡证类和票据类的印刷体识别,也支持运单等手写体识别,支持提供定制化服务,可以有效地代替人工录入信息。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档