1、遍历文件,使用 python 自带的 glob 模块
import glob
result = glob.glob('**/*.py', recursive=True)
print(result)
在使用 glob 模块时,第一个参数指定目标文件的文件名格式,这里可以使用 Linux 中的通配符:
如果文件名写为 *.py ,那么就是当前文件夹下面的所有 .py 文件 。
如果文件名写为 **/*.py ,那么就是当前第一层子文件夹下面的所有 .py 文件 。
如果文件名写为 **/*.py ,并且增加参数 recursive = True ,那么就是递归搜索当前文件夹和所有子文件夹 。
2、MongoDB 正确中断正在创建的索引
import pymongo
handler = pymongo.MongoClient().yourdb.yourcol
# 前台索引
handler.create_index('字段名')
# 后台索引
handler.create_index('字段名', background=True)
索引分为前台索引和后台索引 。如果集合里面有很多数据,并且你使用的是前台索引,那么此时,创建索引会把这个集合锁起来,所有对这个集合的写入操作都会挂起,直到索引创建完成为止 。如果使用的是后台索引,那么创建索引的过程不会影响数据写入。
有时候,本来想创建后台索引,却忘记加 background = True 参数 。 大集合创建索引有时候可能需要好几个小时,挂起的写入数据会堆积在内存里面,把内存撑爆。此时千万不要重启 MongoDB ,因为重启之后,之前没有完成的索引创建操作依然会自动启动继续创建 。正确的做法是杀掉创建索引的进程 。
此时,我们可以在 MongoDB Shell 或者 Robo 3T 里面操作 。这里以 Robo 3T 为例,首先打开对应的集合,然后把命令栏里面的内容修改为 db.currentOp() 。创建索引的进程,可以在参数里面看到类似于 "lockType" : "write" 这样的字段 。在它附近,可以找到一个字段叫做 opid 。然后在命令栏输入命令:db.killOp(opid) 杀掉进程,然后重新创建后台索引即可 。