今天小编要跟大家分享的是,利用Python如何下载抖音无水印的视频;大家可能要问了,这个有什么用呢?当然有用了。那么有什么用呢?下面小编跟大家详细说说。
众所周知,由于如今短视频的火爆,使得一批又一批的自媒体创作者犹如雨后春笋般冒了出来,其中不乏一些创作者投机取巧想要剽窃他人成功作品,这一行为往往被戏称为白嫖,哈哈哈,废话不多说,撸起袖子就是淦。
一、准备
sublime text 3、360浏览器、Python 3.6运行环境
二、需求分析
首先,我们要弄清楚一件事情,抖音视频的水印是怎么生成上去的,什么时候生成上去的,搞清楚这件事情就能很容易找到原视频的地址,然后就可以直接下载了。
三、操作实践
我们打开手机上的一个抖音视频,然后点击复制链接,把链接复制下来然后到电脑浏览器打开,比如说关于李元霸的这个抖音视频:
多少英雄豪杰被黑,只为神化一个痴呆患者李元霸 https://v.douyin.com/wCgKrh/复制此链接,打开【抖音短视频】,直接观看视频!
复制链接在浏览器打开,即可看到这幅画面,如下图:然后我们会发现视频带有抖音字样的水印,很显然这不便于我们白嫖别人的优秀作品,打开审查元素进行查看,如下图:
为了程序的美观,我们可以写个GUI界面的:
class page:
def __init__(self):
self.root=tk.Tk() #初始化窗口
self.root.title('抖音无水印视频下载v1.0') #窗口名称
self.root.geometry("700x700") #设置窗口大小
#设置窗口是否可变,宽不可变,高可变,默认为True
self.root.resizable(width=True,height=True)
#创建标签,文字,背景颜色,字体(颜色,大小),标签的高和宽
self.label1=tk.Label(self.root,text='抖音地址:',font=('宋体',10),width=12,height=2)
#创建输入框,标签高度,字体大小颜色,内容显示方式
self.e1=tk.Entry(self.root,width=30,show=None, font=('Arial', 12))
self.label2=tk.Label(self.root,text='文件名:',font=('宋体',10),width=12,height=2)
#创建输入框,标签高度,字体大小颜色,内容显示方式
self.e2=tk.Entry(self.root,width=30,show=None, font=('Arial', 12))
#创建按钮 内容 宽高 按钮绑定事件
self.b1=tk.Button(self.root, text='无水印下载', width=8,height=1,command=self.download)
self.b2=tk.Button(self.root, text='清空内容', width=8,height=1,command=self.close)
self.photo=tk.PhotoImage(file='111.gif')
self.im=tk.Label(self.root, image=self.photo)
self.photo1=tk.PhotoImage(file='222.gif')
self.im1=tk.Label(self.root, image=self.photo1)
self.dashang=tk.Label(self.root,bg='gray',fg='blue',font=('宋体',12),text='感谢各位的支持,觉得小弟写的不错欢迎打赏,以便于我日后分享更多的精彩作品')
#将所有部件添加到界面中
self.label1.place(x=140,y=30,anchor='nw')
self.e1.place(x=210,y=32,anchor='nw')
self.b2.place(x=500,y=40,anchor='nw')
self.label2.place(x=144,y=60,anchor='nw')
self.e2.place(x=210,y=62,anchor='nw')
self.b1.place(x=230,y=110,anchor='nw')
self.dashang.place(x=60,y=160)
self.im.place(x=10,y=200,width=202,height=313,anchor='nw')
self.im1.place(x=300,y=200,width=202,height=313,anchor='nw')
self.b3=tk.Button(self.root,text='技术博客,点我直达',command=self.refer)
self.b3.place(x=200,y=530,width=140,height=40,anchor='nw')
self.root.mainloop()
效果还不错,可以看看:
接下来我们要写的是下载实现代码段,如下:
def download(self):
url='http://www.zimo.wiki:8080/douyin-video-crawler/api/analysis?url='+self.e1.get()
try:
rep=requests.get(url,timeout=5)
result=rep.text
res=eval(result)
if res.get('msg')=='analysis success':
down_url=res.get('url')
data=requests.get(down_url,stream=True,timeout=4)
with open('{}.mp4'.format(self.e2.get()),'wb') as f:
f.write(data.content)
else:
msg.showwarning('notice','URL Format Error!!!')
except:
return
这里我们是用到了一个抖音解析接口:
http://www.zimo.wiki:8080/douyin-video-crawler/api/analysis?url=
只要在它后面加上抖音视频URL,即可解析出无水印视频,是不是很强大?
我们将地址填写进去访问,发现是这样,如图:
我们把红线指示的地址复制到地址栏就可以访问到无水印视频啦!
拿到真实地址便可以下载了。
为了让他的功能更加完善,我们再加上关闭和跳转操作,如图:
def close(self): #关闭
self.e1.delete(0,'end')
self.e2.delete(0,'end')
def refer(self): #跳转
wb.open('https://url.ms/lypks')
最后当然就是启动该程序啦。
page()
得到如下播放画面:
可以看到,完全没有水印。
四、总结
本文介绍的技术虽然算不上太高端和前沿,但是挺实用的。感谢大家的多多关注与支持,后期我会出更多实用的代码技巧。
想学习更多前端、Python爬虫、大数据等计算机知识,请前往:http://pdcfighting.com/ 想学习更多Python网络爬虫与数据挖掘知识,可前往专业网站:http://pdcfighting.com/