Detect dirty slang in russian text and process it.
Конечно же, бороться с русской ненормативной лексикой очень сложно и данный модуль не претендует на однозначную победу, но помочь в этой борьбе может.
Список слов и регулярные выражения, лежащие в основе модуля, взяты в разное время в забытых местах Интернета и, если кто-то обнаружит своё авторство, то я с радостью это авторство укажу или удалю проприетарную часть по требованию.
В основе модуля лежат два принципа:
- морфологический анализ слов посредством модуля pymorphy2, их сопоставление с базой заранее заготовленных
- анализ текста на основе регулярного выражения.
Можно использовать либо тот, либо другой способ.
Второй вариант работает быстрее, но менее точный. Зато работает вне Django.
Первый вариант медленнее, но его легко "обучать", добавляя слова в список.
Первый вариант также можно использовать вне Django, но Вам придется самим
разобрать базу из файла djantimat/fixtures/initial_data.json
и подменить
свойство PymorphyProc.words
их списком.
Модуль работает только с unicode-объектами.
$ pip install djantimat
Добавление модуля в джанго:
INSTALLED_APPS += ('djantimat',)
синхронизация модели:
$ python manage.py migrate
$ python manage.py syndb # для добавления существующей базы слов
$ python manage.py shell
>>> from djantimat.helpers import PymorphyProc
Есть ли матерные слова в тексте:
>>> slang_detected = PymorphyProc.test(u'Здесь текст с матерками')
Замена матерных слов в тексте шаблоном:
>>> without_slang = PymorphyProc.replace(u'Здесь текст с матерками', repl='[xxx]')
Оборачивание матерных слов в тексте например тегом:
>>> without_slang = PymorphyProc.wrap(u'Здесь текст с матерками', wrap=('<pre>', '</pre>',))
$ python
>>> from djantimat.helpers import RegexpProc
Есть ли матерные слова в тексте:
>>> slang_detected = RegexpProc.test(u'Здесь текст с матерками')
Замена матерных слов в тексте шаблоном:
>>> without_slang = RegexpProc.replace(u'Здесь текст с матерками', repl='[xxx]')
Оборачивание матерных слов в тексте например тегом:
>>> without_slang = RegexpProc.wrap(u'Здесь текст с матерками', wrap=('<pre>', '</pre>',))