Skip to main content

pingparsing is a python library of parsing ping command output.

Project description

pingparsing

https://travis-ci.org/thombashi/pingparsing.svg?branch=master

Summary

pingparsing is a python library of parsing ping command output.

Installation

pip install pingparsing

Premise

This library expects to output language of the ping command is in English. The ping command output in any other languages is may fail to parse. This is because the output of the ping command is changed depending on the language.

Usage

Parsing ping command output

Example: Debian 8.2 w/ iputils-ping 20121221-5+b2

Input
# LC_ALL=C ping google.com -q -c 60 > ping.txt
# cat ping.txt
PING google.com (216.58.196.238) 56(84) bytes of data.

--- google.com ping statistics ---
60 packets transmitted, 60 received, 0% packet loss, time 59153ms
rtt min/avg/max/mdev = 61.425/99.731/212.597/27.566 ms
Sample code

parse_sample.py

import pingparsing

ping_parser = pingparsing.PingParsing()
with open("ping.txt") as f:
    ping_parser.parse(f.read())

print("packet_transmit:", ping_parser.packet_transmit)
print("packet_receive:", ping_parser.packet_receive)
print("packet_loss:", ping_parser.packet_loss)
print("rtt_min:", ping_parser.rtt_min)
print("rtt_avg:", ping_parser.rtt_avg)
print("rtt_max:", ping_parser.rtt_max)
print("rtt_mdev:", ping_parser.rtt_mdev)
print(ping_parser.as_dict())
Output
python parse_sample.py
packet_transmit: 60
packet_receive: 60
packet_loss: 0.0
rtt_min: 61.425
rtt_avg: 99.731
rtt_max: 212.597
rtt_mdev: 27.566
{'rtt_avg': 99.731, 'packet_loss': 0.0, 'packet_transmit': 60, 'rtt_max': 212.597, 'rtt_min': 61.425, 'rtt_mdev': 27.566, 'packet_receive': 60}

Example: Windows 7 SP1

Input
>ping google.com -n 10 > ping_win7.txt

>type ping_win7.txt

Pinging google.com [216.58.196.238] with 32 bytes of data:
Reply from 216.58.196.238: bytes=32 time=87ms TTL=51
Reply from 216.58.196.238: bytes=32 time=97ms TTL=51
Reply from 216.58.196.238: bytes=32 time=56ms TTL=51
Reply from 216.58.196.238: bytes=32 time=95ms TTL=51
Reply from 216.58.196.238: bytes=32 time=194ms TTL=51
Reply from 216.58.196.238: bytes=32 time=98ms TTL=51
Reply from 216.58.196.238: bytes=32 time=93ms TTL=51
Reply from 216.58.196.238: bytes=32 time=96ms TTL=51
Reply from 216.58.196.238: bytes=32 time=96ms TTL=51
Reply from 216.58.196.238: bytes=32 time=165ms TTL=51

Ping statistics for 216.58.196.238:
    Packets: Sent = 10, Received = 10, Lost = 0 (0% loss),
Approximate round trip times in milli-seconds:
    Minimum = 56ms, Maximum = 194ms, Average = 107ms
Sample code

parse_sample.py

import pingparsing

ping_parser = pingparsing.PingParsing()
with open("ping_win7.txt") as f:
    ping_parser.parse(f.read())

print(ping_parser.as_dict())
Output
>python parse_sample.py
{'packet_loss': 0.0, 'packet_receive': 10, 'packet_transmit': 10, 'rtt_min': 56.0, 'rtt_max': 194.0, 'rtt_mdev': None, '
rtt_avg': 107.0}

Execute ping and parse

PingTransmitter class can execute ping command and obtain the ping output as a string.

Sample code

ping_sample.py

import pingparsing

transmitter = pingparsing.PingTransmitter()
transmitter.destination_host = "192.168.0.1"
transmitter.waittime = 60
result = transmitter.ping()

ping_parser = pingparsing.PingParsing()
ping_parser.parse(result)

print(ping_parser.as_dict())

Example execution result: Debian 8.2 w/ iputils-ping 20121221-5+b2

# python ping_sample.py
{'packet_loss': 0.0, 'packet_receive': 60, 'packet_transmit': 60, 'rtt_min': 0.814, 'rtt_max': 27.958, 'rtt_mdev': 3.574, 'rtt_avg': 2.004}

Example execution result: Windows 7 SP1

>python ping_sample.py
{'packet_loss': 0.0, 'packet_receive': 60, 'packet_transmit': 60, 'rtt_min': 0.0
, 'rtt_max': 56.0, 'rtt_mdev': None, 'rtt_avg': 2.0}

Dependencies

Python 2.5+ or 3.3+

Test dependencies

Tested Environment

OS

ping version

Debian 8.2

iputils-ping 20121221-5+b2

Debian 5.0.10

iputils-ping 20071127-1+lenny1

Windows 7 SP1

-

Windows 8.1

-

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pingparsing-0.2.5.tar.gz (8.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pingparsing-0.2.5-py2.py3-none-any.whl (7.3 kB view details)

Uploaded Python 2Python 3

File details

Details for the file pingparsing-0.2.5.tar.gz.

File metadata

  • Download URL: pingparsing-0.2.5.tar.gz
  • Upload date:
  • Size: 8.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for pingparsing-0.2.5.tar.gz
Algorithm Hash digest
SHA256 4aaba269960af3321dd0f97e6dd1dea6aeff9ca6adc8aac1b7ec35c33389f6e2
MD5 a88c612fa47cbdda8c9843284af397db
BLAKE2b-256 03b42b948bcad345d852ae228ac11bf13d7686179053bb6cb77999c02a3f2de6

See more details on using hashes here.

File details

Details for the file pingparsing-0.2.5-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for pingparsing-0.2.5-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 81b463928bcb2018da322bb85c37d5bc89d91659adbe5f00f264160c3616f48c
MD5 c4446c7ba5d1706840feea9d80211936
BLAKE2b-256 93339c6ef9697b99a24479d74d08ab779f8d565d99e9e6986953a2628e10d1b0

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page