Skip to content

samanvp/persian-lexicon

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Persian Lexicon

This repo uses Uppsala Persian Corpus (UPC) to construct a lexicon of 70528 unique words. With all the excitement around game Wordle, we also extracted words with different length (2, 3, 4, ..., 10) and stored them to separate files for easier access. Please note that these files might contain offensive words, I have not check them manually.

GetWords.py can read these files and return words as a list of strings.

Cleanup details

Main Lexicon

The main lexicon (data/persian-words.txt) is build very liberally; we only filter out words that contain ASCII characters or Arabic numerals.

Fixed length Lexicons

More conservative filtering has been applied to files with fixed word length. We drop all words that contain any of the following characters:

Also when calculating length of words we do not take into account Zero-width non-joiner (نیم‌فاصله) characters. For example, "پیش‌بینی‌" length is consider to be 7 rather than 8.

After applying these filters, we ended up with these number of words per file:

  • 2 letter words: 316 unique words
  • 3 letter words: 2389 unique words
  • 4 letter words: 7236 unique words
  • 5 letter words: 11024 unique words
  • 6 letter words: 12507 unique words
  • 7 letter words: 11753 unique words
  • 8 letter words: 9335 unique words
  • 9 letter words: 6113 unique words
  • 10 letter words: 3648 unique words

Filter by part-of-speech tags

Uppsala Persian Corpus (UPC) is annotated with the following 31 part-of-speech tags:

Category Description
ADJ Adjective
ADJ_CMPR Comparative adjective
ADJ_INO Participle adjective
ADJ_SUP Superlative adjective
ADJ_VOC Vocative adjective
ADV Adverb
ADV_COMP Adverb of comparison
ADV_I Adverb of interrogation
ADV_LOC Adverb of location
ADV_NEG Adverb of negation
ADV_TIME Adverb of time
CLITIC Accusative marker
CON Conjunction
DELM Delimiter
DET Determiner
FW Foreign Word
INT Interjection
N_PL Plural noun
N_SING Singular noun
NUM Numeral
N_VOC Vocative noun
P Preposition
PREV Preverbal particle
PRO Pronoun
SYM Symbol
V_AUX Auxiliary verb
V_IMP Imperative verb
V_PA Past tense verb
V_PP Past participle verb
V_PRS Present tense verb
V_SUB Subjunctive verb

You can choose to include only words with certain tags in the output lexicon files. For example, the following command:

python3 Cleanup.py N_PL N_SING  

will generate the output files that only include singular and plural nouns.

About

A lexicon of 70K unique Persian (Farsi) words.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages