文件排序去重新思路
我一直觉得思路是比较重要的。
前几天终于从一个充满了垃圾广告的网盘里下载到了传说中的 csdn 数据库(就是以前泄露的那个,现在被各种封杀了)
我写了个一个python脚本从中提取密码(用户名和邮箱我都不需要),用来做一个字典。
但是我发现,其中有很多是重复的,比如123456789之类的。
所以,第一个问题摆在了我的面前,怎么去重,怎么给文件中的数据去重。
我首先想到的就是python 中的先set在list。
然后我遇到了第二个问题,当这个字典文件比较大的时候,全部读取到内存是不合理的。
通过资料,我查到了一条linux命令,uniq,去重,我的字典有70MB左右,速度还可以接受。
这时候我想到了数据库,数据库设计中有一个约束,叫做唯一性约束,既已经插入的值,不能再次插入。
那么,我读取文件中的数据,尝试往数据库插入,如果数据库中已经存在,我就忽略此次插入。
这就满足了我的需求了。
我的第四个问题,我需要排序,简单的排序就是sorted了,Linux也有sort命令,那么,使用数据库应该也可以排序吧?
这里仅仅是一个思路,我还未做尝试,不过应该可行。