This is the source code for a system to automatically detect potentially idiomatic expressions (PIEs, for short) in text. It has four different methods of doing so: exact string match, fuzzy string match, inflectional string match, and parse-based matching. It relies on a set of digitally available idiom dictionaries to get an inventory of expressions, and extracts all instances of those expressions (with context) from the input corpus.
To run this code, you'll need the following Python setup:
- Python 3.7
- beautifulsoup4 4.5.1
- requests 2.17.3
- nltk 3.2.4
- spacy 2.3.5 + en_core_web_sm(md/lg) 2.3.1
- lxml 3.3.3
Different versions might work just as well, but cannot be guaranteed.
You might also need:
- sPacy pretrined English language model
en_core_web_sm(md/lg)
can be downloaded bypython -m spacy download en_core_web_sm(md/lg)
- morph, if you want to run inflectional string matching.
Stanford CoreNLP, if you want to run the parse-based method with the Stanford parser.the Python library stanfordcorenlp 3.7.0.2(Stanford CoreNLP parsing is currently unavailable.)- the British National Corpus, if you want to extract PIEs from that.
-
Clone the repository
-
Create subdirectories called
working
andext
-
If necessary:
- create a symlink
ext/morph
to the main directory of the morph tools create a symlinkext/stanford
to the main directory of your Stanford CorenNLP installation- create a symlink
ext/BNC
to theTexts
directory of your copy of the BNC
- create a symlink
-
Try and run the system with
python detect_pies.py data/input_sample.txt -d wiktionary -t plain -m exact
. This should extract a list of idioms from Wiktionary and use the exact string match method to extract PIEs from the input sample file. -
Get an overview of all options by simply running
python detect_pies.py --help
For any questions about (running) the system, feel free to contact me at [email protected]
Note: Adapted for Python 3.x setup by yeonju123