Элементарная напоминалка для Linux
Примеры Python » Python для начинающих python модули, python примеры, программирование на python
Офисные сотрудники привыкли к тому, что на них одновременно весит несколько задач. Не успел сделать одно, или даже начать делать, как просят о чем-то другом. Запомнить все и нечего не упустить довольно тяжело.
Эту ситуацию можно значительно упростить благодаря простой напоминалке. Работать она должна так:
- Комбинацией клавиш открываем диалоговое окно напоминалки.
- Вводим текст задачи и время, причем простыми словами, к примеру «перезвонить Сергею через 30 минут», «отправить отчет в 14» или «в 12-14 обед».
- Клацаем Enter.
- В указанное время сработает напоминание, которое можно отложить либо закрыть.
Для Windows есть масса готовых решений, к примеру XMinder. Но, нет аналога такой программы для Linux. Есть конечно подобные программы, но работают они не так, и не настолько просты.
Поэтому было решено самостоятельно написать такую программку. Для реализации такой задачи были выбраны Python, Bash, Zenity и At.
Выбор пал на Pyrhon, потому что по нему существует очень много хорошей документации, и он стандартно уже есть в дистрибутивах. Да и решить такую задачу сможет даже новичок.
Bash был выбран для того, чтобы можно было создать удобную функцию «Отложить».
Zenity опять таки выбран из-за простоты, лаконичности и наличия в большинстве дистрибутивов Linux «из коробки».
А At выбран потому, что именно на него возлагается решение задачи. И он сохраняет данные даже в случае перезагрузки компьютера.
Соответственно, был выбран комплекс из нескольких программ, а к ним добавлен необходимый синтаксис.
В результате было создано 2 файла:
Remind.py
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# RemindMe v1.5 created by Dennis Smal' in 2014 godgrace@mail.ru
from __future__ import print_function
import subprocess
import re
import sys
def replace_all(t, d):
"""Общая функция для подмены переменных"""
for i, j in d.iteritems():
t = t.replace(i, j, 1)
return t
def get_datex(text):
"""Извлекает из текста дату и подстроку с датой, которую нужно удалить"""
whatdate = ''
delwhatdate = ''
datex = re.findall(r'\d{2}[.,-]\d{2}[.,-]\d{4}|\d{1}[.,-]\d{2}[.,-]\d{4}',text) # ищем дату в формате 19.08.2014 или 19-08-2014 или 19,08,2014
if datex:
date = datex[0].replace('-','.').replace(',','.') # преобразуем дату в формат 19.08.2014
whatdate = date
delwhatdate = datex[0]+' '
return whatdate, delwhatdate
def get_day(text):
"""Извлекает из текста день недели и подстроку, которую нужно удалить"""
when = ''
delday = ''
day = re.findall('завтра|Завтра|в понедельник|во вторник|в среду|в четверг|в пятницу|в субботу|в воскресенье',text)
daywithoutin = re.findall('понедельник|вторник|среда|четверг|пятница|суббота|воскресенье',text)
if day:
ind = {'завтра':'tomorrow', 'Завтра':'tomorrow', 'в понедельник':'mon', 'во вторник':'tue', 'в среду':'wed', 'в четверг':'thu', 'в пятницу':'fri', 'в субботу':'sat', 'в воскресенье':'sun'}
when = replace_all(day[0], ind)
delday = day[0]+' '
elif daywithoutin:
ind = {'понедельник':'mon', 'вторник':'tue', 'среда':'wed', 'четверг':'thu', 'пятница':'fri', 'суббота':'sat', 'воскресенье':'sun'}
when = replace_all(daywithoutin[0], ind)
delday = daywithoutin[0]+' '
return (when, delday)
def get_clock(text):
"""Извлекает из текста время и подстроку, которую нужно удалить"""
how = ''
delclock = ''
clock = re.findall('минуты |часа |дня |минуту |часов |день |минут |час |дней ',text)
if clock: # смотрим, есть ли указание на часы, минуты, дни
clockbank = {'минут ':'min', 'час ':'hour', 'дней ':'days', 'минуту ':'min', 'часа ':'hours', 'дня ':'days', 'минуты ':'min', 'часов ':'hours', 'день ':'days'}
how = replace_all(clock[0], clockbank)
delclock = clock[0]
return (how, delclock)
def add_task(out, x):
"""Добавляет напоминание в очередь at"""
#для отладки, чтобы долго не ждать
#x = 'at now'
#print (x)
cmd = 'echo "DISPLAY=:0 ~/remindme/task %s" | %s' % (out, x)
subprocess.Popen(cmd, shell=True)
def main(when="Через 15 минут", reminder=""):
warn_cmd = [
'zenity',
'--warning',
'--text="Попробуйте ещё раз.."'
]
cmd = [
'zenity',
'--entry',
'--title=Напоминалка',
'--text=Введите напоминание',
'--entry-text={} {}'.format(when, reminder),
'--width=400'
]
loop = True
while loop:
get = subprocess.check_output(cmd) # получаем текст
text = get+' ' # добавляем в конец пробел, чтобы отрабатывать уведомления типа "напомнить мне через 10 минут". Если бы пробела не было, параметр clock был бы пуст. В параметре clock после слова "час" тоже стоит пробел, чтобы различать поиск "час" и "часов".
find = re.findall('ерез [0-9]+|В [0-9:-]+|в [0-9:-]+|ерез час',text)
if get: # убеждаемся, заполнено ли поле ввода
if find: # убеждаемся, указано ли время напоминания
what = find[0].split()
timex = what[1].replace('-',':').replace('час','1')
if len(timex) > 2: # заменяет выражения типа "в 10" на "в 10:00"
time = timex
else:
time = timex+':00'
whatdate, delwhatdate = get_datex(text)
when, delday = get_day(text)
how, delclock = get_clock(text)
reps = {'ерез':'at now + %s %s' % (timex,how),'В':'at %s %s %s' % (time,when,whatdate),'в':'at %s %s %s' % (time,when,whatdate)}
wors = {'Через %s %s' % (what[1],delclock):'','через %s %s' % (what[1],delclock):'','В %s ' % what[1]:'','в %s ' % what[1]:'', '%s' % delday:'', 'Через час':'', 'через час':'', '%s' % delwhatdate:'',} # какие слова мы будем удалять
x = replace_all(what[0], reps) # это время, на которое запланировано появление напоминания
out = replace_all(text, wors) # это текст напоминания
add_task(out, x)
loop = False
else:
error = subprocess.check_output(warn_cmd)
else:
loop = False
def usage():
s = "Использование: {} [Время напоминания [Напоминание]]".format(__file__)
print(s)
if __name__ == "__main__":
if len(sys.argv) <= 3:
main(*sys.argv[1:])
else:
usage()
И task:
#!/bin/bash
zenity --question --title=Напоминание --ok-label=Отложить --cancel-label=Ok --text="$*"
case $? in
0) ~/remindme/remind.py "Через 15 минут" "$*"
;;
1)
;;
esac
Эти файлики необходимо разместить в одной директории и дать им права на исполнение (к примеру, через команду chmod +x). Для файла remind.py назначаем комбинацию горячих клавиш (в каждом дистрибутиве эта возможность реализована по-разному).
На этом все, простая напоминалка готова.
Этот проект есть на GitHub, откуда вы и сможете его загрузить - https://github.com/vsile/remindme.git
Нужен качественный хостинг веб сайтов? Тогда рекомендую воспользоваться предложением от REG.RU. Идеальное соотношение цена/качество, полное отсутствие каких-либо проблем, отключений, тормозов и т.д., оперативная техподдержка.
- Взаимодействие с Интернетом. Разбор URL-адреса в Python
- Веб-программирование в Python. Создание и запуск сайтов на Python
- Изучение языка программирования Python с помощью Brain Up!
- Работа со списками Python
- Стандартные библиотеки и сторонние библиотеки Python
- Права доступа к файлам и каталогам
- Работаем с Яндекс.Метрикой на Python