freebsd-nq/usr.bin/fortune/tools/do_uniq.py
Craig Rodrigues 749f65e3e3 Use print as a function for Python 3 [PEP 3105]
Import print_function from the __future__ module
to activate this for Python 2.  This works as far back as Python 2.6.0a2:
   https://docs.python.org/2/library/__future__.html

[PEP 3105] https://www.python.org/dev/peps/pep-3105/
2015-11-19 00:01:52 +00:00

69 lines
1.8 KiB
Python

#!/usr/local/bin/python
#
# $FreeBSD$
#
# an aggressive little script for trimming duplicate cookies
from __future__ import print_function
import argparse
import re
wordlist = [
'hadnot',
'donot', 'hadnt',
'dont', 'have', 'more', 'will', 'your',
'and', 'are', 'had', 'the', 'you',
'am', 'an', 'is', 'll', 've', 'we',
'a', 'd', 'i', 'm', 's',
]
def hash(fortune):
f = fortune
f = f.lower()
f = re.sub('[\W_]', '', f)
for word in wordlist:
f = re.sub(word, '', f)
# f = re.sub('[aeiouy]', '', f)
# f = re.sub('[^aeiouy]', '', f)
f = f[:30]
# f = f[-30:]
return f
def edit(datfile):
dups = {}
fortunes = []
fortune = ""
with open(datfile, "r") as datfiledf:
for line in datfiledf:
if line == "%\n":
key = hash(fortune)
if key not in dups:
dups[key] = []
dups[key].append(fortune)
fortunes.append(fortune)
fortune = ""
else:
fortune += line
for key in list(dups.keys()):
if len(dups[key]) == 1:
del dups[key]
with open(datfile + "~", "w") as o:
for fortune in fortunes:
key = hash(fortune)
if key in dups:
print('\n' * 50)
for f in dups[key]:
if f != fortune:
print(f, '%')
print(fortune, '%')
if input("Remove last fortune? ") == 'y':
del dups[key]
continue
o.write(fortune + "%\n")
parser = argparse.ArgumentParser(description="trimming duplicate cookies")
parser.add_argument("filename", type=str, nargs=1)
args = parser.parse_args()
edit(args.filename[0])