百度云“资源”被和谐,两行代码帮你解决

用了几年了,成功率大概在80%以上。

很多人在百度云上都有这样的经历,辛苦下载的视频上传到百度云后,一段时间后会变成8秒的“净网”广告。

如果出现上面的界面,恭喜你,基本上没救了,趁早删了视频节省下空间吧。

想了一下,百度大概有种几种手段来判断视频问题。

  1. 安排人员去做视频排查,查一个标记一个。
  2. 抽查一些视频,利用视频数据帧截取一些视频图片,再进行排查
  3. 比较视频的MD5码

1是不可能的,最有可能就是2跟3一起。先利用视频里面的一些载图来标定是不是不合法的视频,这个判断有可能会误杀一些视频,但是同时也可能会漏掉一些视频。

有些视频刚上传上去就会被判断出来,并且有些文件基本上是秒传的,所以说明百度云里面是根据MD5来判断的。每个文件对应一个MD5,一个文件百度云上保存一份,后面其它人上传的时候,不管文件是什么名称,只要判断MD5是一样的,复制一个链接给他就行了, 不用再上传文件,这样节省了服务器带宽,也节省了用户的时间。目前所有的云存储都是这样实现的。

也说明了修改文件的名称是没有用的,修改文件的名称是没有用的,修改文件的名称是没有用的

为啥,因为MD5不包含文件名称属性。

知道这个原理后,解决百度云 净网行动应该很简单了。

fo = open("test.mp4", "w")
     fo.write("ah")

打开文件,然后在文件后面追加几个字符,这几个字符你随便写。不影响整体文件播放。

亲测有效。是不是两行。

当然我是比较懒的,不可能一个视频一个视频的处理,所以我把文件夹下面的视频文件都修改了,可以参考下面的代码。

# -*- coding: utf-8 -*-

import hashlib
import shutil
import os
from os import walk
from os import listdir


def get_filepaths(directory):
    file_paths = []  # List which will store all of the full filepaths.

    for root, directories, files in os.walk(directory):
        for filename in files:
            filepath = os.path.join(root, filename)
            extension = os.path.splitext(filename)[1][1:]
            if extension in ("jpg", "png", "torrent"):
                os.remove(filepath)
            else:
                file_paths.append(filepath)  # Add it to the list.

    return file_paths  

dir = "D://xunleidown//private" // your dir 
new_file_name = []

files = get_filepaths(dir)

for file in files:
    filename, file_extension = os.path.splitext(file)
    new_file_name = filename + "bak" + file_extension

    with open(file, "a") as testFile:
        testFile.write("ah")

print "done"

如发现错误或看不懂的地方,可在评论区提出,大家一起交流!

如果文章对您有帮助,点赞+关注,您的支持是我最大的动力

你可能感兴趣的:(python百度云)