关于Python有一句名言:不要重复造轮子。但是问题有三个:
1、你不知道已经有哪些轮子已经造好了,哪个适合你用。有名有姓的的著名轮子就400多个,更别说没名没姓自己在制造中的轮子。
2、确实没重复造轮子,但是在重复制造汽车。包括好多大神写的好几百行代码,为的是解决一个Excel本身就有的成熟功能。
3、很多人是用来抓图,数据,抓点图片、视频、天气预报自娱自乐一下,然后呢?抓到大数据以后做什么用呢?比如某某啤酒卖的快,然后呢?比如某某电影票房多,然后呢?
以下是经过Python3.6.4调试通过的代码,与大家分享:
-
抓取知乎图片
-
听两个聊天机器人互相聊天
-
AI分析唐诗的作者是李白还是杜甫
-
彩票随机生成35选7
-
自动写检讨书
-
屏幕录相机
-
制作Gif动图
抓取知乎图片,只用30行代码
from selenium import webdriver
import time
import urllib.requestdriver = webdriver.Chrome()
driver.maximize_window()
driver.get("https://www.zhihu.com/question/29134042")
i = 0
while i < 10:driver.execute_script("window.scrollTo(0, document.body.scrollHeight);")time.sleep(2)try:driver.find_element_by_css_selector(&#39;button.QuestionMainAction&#39;).click()print("page" &#43; str(i))time.sleep(1)except:break
result_raw &#61; driver.page_source
content_list &#61; re.findall("img src&#61;\"(.&#43;?)\" ", str(result_raw))
n &#61; 0
while n < len(content_list):i &#61; time.time()local &#61; (r"%s.jpg" % (i))urllib.request.urlretrieve(content_list[n], local)print("编号&#xff1a;" &#43; str(i))n &#61; n &#43; 1
无聊的时候&#xff0c;听两个聊天机器人互相聊天
from time import sleep
import requests
s &#61; input("请主人输入话题&#xff1a;")
while True:resp &#61; requests.post("http://www.tuling123.com/openapi/api",data&#61;{"key":"4fede3c4384846b9a7d0456a5e1e2943", "info": s, })resp &#61; resp.json()sleep(1)print(&#39;小鱼&#xff1a;&#39;, resp[&#39;text&#39;])s &#61; resp[&#39;text&#39;]resp &#61; requests.get("http://api.qingyunke.com/api.php", {&#39;key&#39;: &#39;free&#39;, &#39;appid&#39;:0, &#39;msg&#39;: s})resp.encoding &#61; &#39;utf8&#39;resp &#61; resp.json()sleep(1)print(&#39;菲菲&#xff1a;&#39;, resp[&#39;content&#39;])
#网上还有一个据说智商比较高的小i机器人&#xff0c;用爬虫的功能来实现一下&#xff1a;import urllib.request
import rewhile True:x &#61; input("主人&#xff1a;")x &#61; urllib.parse.quote(x)link &#61; urllib.request.urlopen("http://nlp.xiaoi.com/robot/webrobot?&callback&#61;__webrobot_processMsg&data&#61;%7B%22sessionId%22%3A%22ff725c236e5245a3ac825b2dd88a7501%22%2C%22robotId%22%3A%22webbot%22%2C%22userId%22%3A%227cd29df3450745fbbdcf1a462e6c58e6%22%2C%22body%22%3A%7B%22content%22%3A%22" &#43; x &#43; "%22%7D%2C%22type%22%3A%22txt%22%7D")html_doc &#61; link.read().decode()reply_list &#61; re.findall(r&#39;\"content\":\"(.&#43;?)\\r\\n\"&#39;, html_doc)print("小i&#xff1a;" &#43; reply_list[-1])
分析唐诗的作者是李白还是杜甫
import jieba
from nltk.classify import NaiveBayesClassifier# 需要提前把李白的诗收集一下&#xff0c;放在libai.txt文本中。
text1 &#61; open(r"libai.txt", "rb").read()
list1 &#61; jieba.cut(text1)
result1 &#61; " ".join(list1)
# 需要提前把杜甫的诗收集一下&#xff0c;放在dufu.txt文本中。
text2 &#61; open(r"dufu.txt", "rb").read()
list2 &#61; jieba.cut(text2)
result2 &#61; " ".join(list2)# 数据准备
libai &#61; result1
dufu &#61; result2# 特征提取
def word_feats(words):return dict([(word, True) for word in words])libai_features &#61; [(word_feats(lb), &#39;lb&#39;) for lb in libai]
dufu_features &#61; [(word_feats(df), &#39;df&#39;) for df in dufu]
train_set &#61; libai_features &#43; dufu_features
# 训练决策
classifier &#61; NaiveBayesClassifier.train(train_set)# 分析测试
sentence &#61; input("请输入一句你喜欢的诗&#xff1a;")
print("\n")
seg_list &#61; jieba.cut(sentence)
result1 &#61; " ".join(seg_list)
words &#61; result1.split(" ")# 统计结果lb &#61; 0
df &#61; 0
for word in words:classResult &#61; classifier.classify(word_feats(word))if classResult &#61;&#61; &#39;lb&#39;:lb &#61; lb &#43; 1if classResult &#61;&#61; &#39;df&#39;:df &#61; df &#43; 1# 呈现比例
x &#61; float(str(float(lb) / len(words)))
y &#61; float(str(float(df) / len(words)))
print(&#39;李白的可能性&#xff1a;%.2f%%&#39; % (x * 100))
print(&#39;杜甫的可能性&#xff1a;%.2f%%&#39; % (y * 100))
彩票随机生成35选7
import randomtemp &#61; [i &#43; 1 for i in range(35)]
random.shuffle(temp)
i &#61; 0
list &#61; []
while i < 7:list.append(temp[i])i &#61; i &#43; 1
list.sort()
print(&#39;\033[0;31;;1m&#39;)
print(*list[0:6], end&#61;"")
print(&#39;\033[0;34;;1m&#39;, end&#61;" ")
print(list[-1])
自动写检讨书
import random
import xlrdExcelFile &#61; xlrd.open_workbook(r&#39;test.xlsx&#39;)
sheet &#61; ExcelFile.sheet_by_name(&#39;Sheet1&#39;)
i &#61; []
x &#61; input("请输入具体事件&#xff1a;")
y &#61; int(input("老师要求的字数&#xff1a;"))
while len(str(i)) < y * 1.2:s &#61; random.randint(1, 60)rows &#61; sheet.row_values(s)i.append(*rows)
print(" "*8&#43;"检讨书"&#43;"\n"&#43;"老师&#xff1a;")
print("我不应该" &#43; str(x)&#43;"&#xff0c;", *i)
print("再次请老师原谅&#xff01;")
&#39;&#39;&#39;
以下是样稿&#xff1a;请输入具体事件&#xff1a;抽烟
老师要求的字数&#xff1a;200检讨书
老师&#xff1a;
我不应该抽烟&#xff0c; 学校一开学就三令五申&#xff0c;一再强调校规校纪&#xff0c;提醒学生不要违反校规&#xff0c;可我却没有把学校和老师的话放在心上&#xff0c;没有重视老师说的话&#xff0c;没有重视学校颁布的重要事项&#xff0c;当成了耳旁风&#xff0c;这些都是不应该的。同时也真诚地希望老师能继续关心和支持我&#xff0c;并却对我的问题酌情处理。 无论在学习还是在别的方面我都会用校规来严格要求自己&#xff0c;我会把握这次机会。 但事实证明&#xff0c;仅仅是热情投入、刻苦努力、钻研学业是不够的&#xff0c;还要有清醒的政治头脑、大局意识和纪律观念&#xff0c;否则就会在学习上迷失方向&#xff0c;使国家和学校受损失。
再次请老师原谅&#xff01;
&#39;&#39;&#39;
屏幕录相机&#xff0c;抓屏软件
from time import sleep
from PIL import ImageGrabm &#61; int(input("请输入想抓屏几分钟&#xff1a;"))
m &#61; m * 60
n &#61; 1
while n < m:sleep(0.02)im &#61; ImageGrab.grab()local &#61; (r"%s.jpg" % (n))im.save(local, &#39;jpeg&#39;)n &#61; n &#43; 1
制作Gif动图
from PIL import Imageim &#61; Image.open("1.jpg")
images &#61; []
images.append(Image.open(&#39;2.jpg&#39;))
images.append(Image.open(&#39;3.jpg&#39;))
im.save(&#39;gif.gif&#39;, save_all&#61;True, append_images&#61;images, loop&#61;1, duration&#61;1, comment&#61;b"aaabb")
【python学习】
学Python的伙伴,欢迎加入新的交流【君羊】&#xff1a;1020465983
一起探讨编程知识,成为大神,群里还有软件安装包&#xff0c;实战案例、学习资料