Python - ayuda con datetime, timedelta...

 
Vista:

ayuda con datetime, timedelta...

Publicado por cristian (1 intervención) el 27/04/2018 21:37:35
hola buenas, tengo este codigo que me dice las ip que intentan acceder al sistema de forma fallida en un intervalo de tiempo (fechas), me gustaria hacer lo mismo pero comprobandolo en un tiempo determinado, por ejemplo 5minutos sin tener que introducir toda la fecha.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#!/usr/bin/env python
#-*- coding: utf-8 -*-
from datetime import datetime
 
# Ejemplo formato de funcion: ana('Nov 24 05:45:22','Nov 26 05:45:22', 12)
def ana(fechainicio, fechafinal, nrepeticiones):
 
	ficherolog = open ('auth.log', 'r')
	fechainicio=datetime.strptime(fechainicio,'%b %d %H:%M:%S')
	fechafinal=datetime.strptime(fechafinal,'%b %d %H:%M:%S')
	ipfalladas=[]
	iprepetida=[]
	for linea in ficherolog.readlines():
		if 'authentication failure' in linea:
			li=linea.split()
			sfe = li[0]+li[1]+li[2]
			fe = datetime.strptime(sfe,'%b%d%H:%M:%S')
			for ele in li:
				if 'rhost' in ele:
					ip = ele[6:]
			if fe >= fechainicio and fe <= fechafinal:
				ipfalladas.append(ip)
				for ip in ipfalladas:
					if ipfalladas.count(ip)>=nrepeticiones:
						if ip not in iprepetida:
							iprepetida.append(ip)
	return iprepetida
	ficherolog.close()
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder
Imágen de perfil de algoritmo
Val: 819
Bronce
Ha mantenido su posición en Python (en relación al último mes)
Gráfica de Python

ayuda con datetime, timedelta...

Publicado por algoritmo (245 intervenciones) el 28/04/2018 23:49:18
Prueba con:

from datetime import timedelta

fechafinal = fechainicio+timedelta(minutes=5)
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar