mirror of
https://github.com/nhammer514/textfiles-politics.git
synced 2025-01-04 12:11:10 -05:00
47 lines
1.6 KiB
Python
47 lines
1.6 KiB
Python
###### Original name checker thing ######
|
|
|
|
import spacy
|
|
from collections import Counter
|
|
import re as regex
|
|
import os
|
|
# nlp = spacy.cli.download("en_core_web_lg")
|
|
# If you already have it, comment it ou.
|
|
# Let's try the different spaCy language models for this. We can compare _lg with _md or _sm
|
|
workingDir = os.getcwd()
|
|
CollPath = os.path.join(workingDir, '../regexConsp')
|
|
insideDir = os.listdir(CollPath)
|
|
print(insideDir)
|
|
|
|
if os.path.isfile("outputNames.txt"):
|
|
open("outputNames.txt", 'w').close();
|
|
|
|
nlp = spacy.load("en_core_web_lg")
|
|
def readTextFiles(filepath):
|
|
with open(filepath, 'r', encoding='utf8') as f:
|
|
readFile = f.read()
|
|
stringFile = str(readFile)
|
|
# Using REGEX to delete all element tags.
|
|
elementsRemoved = regex.sub('<.+?>', '', stringFile)
|
|
# Using REGEX to delete all \n.
|
|
cleanedFile = regex.sub('\n', ' ', elementsRemoved)
|
|
tokens = nlp(cleanedFile)
|
|
|
|
listEntities = entitycollector(tokens)
|
|
|
|
def entitycollector(tokens):
|
|
entities = []
|
|
for entity in tokens.ents:
|
|
if entity.label_ == "PERSON":
|
|
with open("outputNames.txt", 'a') as f:
|
|
f.write("\n" + entity.text)
|
|
print("Writing in outputNames.txt: " + entity.text)
|
|
## Below includes entity values and stuf
|
|
# print(entity.text, entity.label_, spacy.explain(entity.label_))
|
|
entities.append(entity.text)
|
|
return entities
|
|
|
|
for file in os.listdir(CollPath):
|
|
if file.endswith(".xml"):
|
|
filepath = f"{CollPath}/{file}"
|
|
print(filepath)
|
|
readTextFiles(filepath) |