Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

find_gromots.py 962B

12345678910111213141516171819202122232425262728293031323334353637383940
  1. from datetime import datetime
  2. from million.analyze.word_finder import findWords
  3. import million.parse.fb_exports as fb
  4. DATA_PATH = './data/'
  5. gros_mots = [
  6. '.*merde.*',
  7. 'sexe',
  8. 'pute',
  9. 'pé?dé?',
  10. 'putain',
  11. 'bite',
  12. 'encul.*',
  13. 'cul',
  14. 'nichon',
  15. 'gueule',
  16. 'con(ne)?',
  17. 'chatte',
  18. 'niqu.*',
  19. 'chi(é|e).*',
  20. 'bais.*'
  21. ]
  22. export = fb.parse_dirfiles(DATA_PATH)
  23. msg_gros_mots = findWords(export.messages, gros_mots)
  24. msg_gros_mots_grp = {}
  25. for msg in msg_gros_mots:
  26. if msg.sender_name not in msg_gros_mots_grp: msg_gros_mots_grp[msg.sender_name] = []
  27. msg_gros_mots_grp[msg.sender_name].append(msg)
  28. for name in sorted(msg_gros_mots_grp, key = lambda k: len(msg_gros_mots_grp[k])):
  29. print(name)
  30. for msg in msg_gros_mots_grp[name]:
  31. time = datetime.fromtimestamp(msg.timestamp_ms / 1000)
  32. time_str = time.strftime("%d/%m/%Y %H:%M:%S")
  33. print(f"\t{time_str} : {msg.content}")