logging, can one get it to email messages over a certain level?
tinnews at isbd.co.uk
tinnews at isbd.co.uk
Mon Nov 12 06:36:47 EST 2012
Peter Otten <__peter__ at web.de> wrote:
> tinnews at isbd.co.uk wrote:
>
> > Steve Howell <showell30 at yahoo.com> wrote:
> >> On Nov 11, 9:48 am, tinn... at isbd.co.uk wrote:
> >> > I'm sure this must be possible but at the moment I can't see how to do
> >> > it.
> >> >
> >> > I want to send an E-Mail when the logging module logs a message above
> >> > a certain level (probably for ERROR and CRITICAL messages only).
> >> >
> >> > I.e. I want some sort of hook that will be called when these messages
> >> > are logged (I can do the sendmail bit OK, I've got code that does
> >> > that).
> >> >
> >> > --
> >> > Chris Green
> >>
> >> Scroll down to the Handlers section here:
> >>
> >> http://docs.python.org/2/howto/logging.html#logging-basic-tutorial
> >>
> >> I'm not sure this explains perfectly what you're gonna need to do, but
> >> I hope it gets you in the ballpark.
> >>
> > Thank you, but yes I agree it's not terribly informative is it.
>
> Here's a minimal example:
>
> import logging
> from logging.handlers import SMTPHandler
>
> if __name__ == "__main__":
> logging.basicConfig(level=logging.INFO)
>
> mail_handler = SMTPHandler(
> "smtp.example.com",
> "navigator at example.com",
> "captain.nemo at example.com",
> "fyi")
> mail_handler.setLevel(logging.CRITICAL)
>
> root = logging.getLogger()
> root.addHandler(mail_handler)
>
> # will print amessage
> root.warn("this is fishy")
>
> # will print a message and send an email
> root.critical("giant squid sighted")
>
Thank you.
--
Chris Green
More information about the Python-list
mailing list