-
Notifications
You must be signed in to change notification settings - Fork 0
/
PositionalInvertedIndexer.py
58 lines (45 loc) · 1.5 KB
/
PositionalInvertedIndexer.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
'''
PositionalInvertedIndexer: main driver app for the InvertedIndex
'''
# save each file path into a dic
from PositionalInvertedIndex import PositionalInvertedIndex
from Corpus import Corpus
from nltk.tokenize import word_tokenize
from nltk.corpus import stopwords
from nltk.stem import PorterStemmer
directory = './MobyDick10Chapters'
def searchengine(directory):
stopWords = set(stopwords.words("english"))
# stemming
ps = PorterStemmer()
# create InvertedIndex obj
positionalInvertedIndex = PositionalInvertedIndex()
# build the corpus
Corp = Corpus()
corpus = Corp.buildCorpus(directory)
for docId in corpus:
position = 1
doc = corpus[docId]
content = doc.getContent()
# tokenize
tokens = word_tokenize(content)
for token in tokens:
token = token.lower()
# apply stemming
token = ps.stem(token)
# remove stopwords
if token in stopWords:
continue
# add to index
positionalInvertedIndex.addTerm(token, docId, position)
position +=1
return positionalInvertedIndex, corpus
indexer, corpus = searchengine(directory)
term ='how long'
#need to normalize the token as well
postlist = indexer.getPostings(term)
print('searching for \"', term, '\"')
print('Found ___ ', term,' ___ in: ')
for p in postlist:
print(corpus[p.getDocumentId()].getTitle())
# print(len(indexer.getVocabulary()))