查看原文
其他

使用Python自动化发布文章:(一)

By Python绿色通道 2019-05-24


用Python做有趣的事情

写在前面:坚持解决一个问题,花了两三个小时的时间终于解决了问题,最后我的自动化发布文章的功能终于实现了。

想法来源:玩自媒体的朋友都知道,如果把自己的文章同步到多个平台就需要每个平台都需要登录一下,再重新发布一下,所以我就在想能不能让Python来一键完成这些操作呢!

于是放假的这两天我就开始做了一个雏形,总算做好了。效果图如下:


首先我先在开源中国上发来进行小小的练手,为什么选这个网站呢?因为这个网站没有要求输入验证码,哈哈,验证码的问题就避免了,另外因为每个平台的验证码都不一样,所以处理机制也不一样,所以我本人也不想针对验证码来处理验证码问题。除非是大平台,我可能会单独处理一下,其它的小平台我都打算用cookie来绕过验证码问题!

实现思路

  • 使用selenium来模拟登录到开源中国平台上

  • 切换到写博客的网页中

  • 给博客中的标题,内容进行内容填充

  • 选择博客类型,这里有点麻烦,花了好大精力,通过直接修改js来更改的。

  • 提交,就可以看到内容发布

完整代码

# coding:utf-8


from selenium import webdriver
import time

user_main_url = 'https://my.oschina.net/u'

username = 'XXX'
password = 'XXX'

url = 'https://www.oschina.net/home/login?goto_page=https%3A%2F%2Fmy.oschina.net%2Fu%2F564070%2Fblog'

driver = webdriver.Firefox()
driver.get(url)

# 浏览器窗口最大化
driver.maximize_window()

driver.find_element_by_id('userMail').send_keys(username)
driver.find_element_by_id('userPassword').send_keys(password)
driver.find_element_by_xpath('//*[@id="account_login"]/form/div/div[5]/button').click()


# 进入主页
while True:
   # 判断是不是在个人主页中。
   if user_main_url in driver.current_url:
       break
   else:
       # 不在个人主页中就继续加载了。
       time.sleep(1)


# 点击进入写作页。
driver.find_element_by_xpath('/html/body/div/div/div/div/div[1]/div[1]/div[4]/a').click()

time.sleep(1)

# 填写标题
titleInput = driver.find_element_by_xpath('//*[@id="title"]')
titleInput.send_keys(u'666666模333444444')

# 填写内容
contentInput = driver.find_element_by_id('mdeditor')
contentInput.send_keys(u'666666模拟3334444422222。。。。。')



#通过网页源代码可以查看value=428612正好对应着前端开发。
# 选择文章的类型值,
js = 'document.getElementById("sys_sort").value="428612";'
driver.execute_script(js)


# 修改选择的类型文本
js = 'document.getElementsByClassName("select-show")[2].innerText="前端开发";'
driver.execute_script(js)


# 点击提交
submit = driver.find_element_by_xpath('//*[@id="blog-form"]/div[3]/div/button[2]')
submit.click()

print '发布成功!'

当然这样还只是一个非常粗糙的实现。后面我会进一步优化,敬请期待。有啥好意见欢迎留言!


推荐阅读:

做微信公众号100天了

Python爬虫:使用Python动态爬取冯大辉老师微博,再用词云分析

Python爬虫:动态爬取QQ说说并生成词云,分析朋友状况

Python爬虫:学习Selenium并使用Selenium模拟登录知乎

Python爬取大量数据时,如何防止IP被封

Python爬虫:现学现用xpath爬取豆瓣音乐


您的Python之旅

长按,识别二维码,关注公众号



目前10000+人已关注加入我们

       

       


关注微信公众号(Python绿色通道)即可领取5T学习资料: 数据结构, 小程序, 前端, PHP, Java ,Android, Python, 大数据, 人工智能等!


公众号后台回复 红包,获取福利。


最后 :大家也可以加我个人微信:hg_liuzl,  注明:Python学习,拉你进群学习,一个纯粹的Python学习环境


    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存