Jump to content
edmin

Ajuda com código

Recommended Posts

Olá pessoal, preciso de uma ajuda como seguinte, desde já, agradeço por qualquer ajuda...

Pergunta: 

Dado um arquivo 'ips.txt' com uma lista de endereços, o programa deve dar um ping para cada ip/domínio cadastrado. A linha contendo os resultados (mínimo, máximo, média)deve ser salva em arquivo 'log_data_hora.txt'.

ips.txt

www.claro.com.br;Servidor Claro
www.colombo.com.br;Servidor Colombo
www.renner.com.br;Servidor Renner
www.gmail.com.br;Servidor Email Google
 

tenho o seguinte código:

 

import os
from datetime import datetime
def titulo(texto):
    print()
    print(texto)
    print('\033[7;97;40m-\033[m'*40)


######################################
def listar():
    print('\033[7;97;40mListagem de IPs\033[m')
    print('\033[7;97;40m=\033[m'*72)
    arq = open('ips.txt', 'r')
    num = 0
    linha = arq.readline()
    print('\033[7;97;40mNº .: IP/Dominio ...............:   Cliente/Serviço ..................: \033[m')
    while linha != '':
        num = num + 1
        partes = linha.split(';')
        print(f'\033[7;97;40m {num:3}   {partes[0]:30s}   {partes[1][:-1]}\033[m')
        linha = arq.readline()
    arq.close()
    print('\033[7;97;40m-\033[m'*72)

'''
funcao que recebe um ip como parametro
o tempo medio de resposta de um ping para este ip
ou -1, caso erro
'''

def ver_media(ip):
    dados = os.popen('ping '+ ip) # executa um comando no sistema operacional
    media = ''
    #find: retorna a posicao da string
    #(se nao encontrar retorna 0)
    for linha in dados:
        if linha.find('M‚dia') >= 0:
            posicao = linha.rfind('=')
            mediams = linha[posicao+1:]
            ms = mediams.rfind('ms')
            media = mediams[0:ms]

    if media == '':
        return -1
    else:
        return int(media)


def testar():
    titulo('\033[7;97;40mTestando IPs Cadastrados\003[m')
    print('\033[7;97;40mIP/Domínio............ Tempo(ms)\033[m')
    print('\033[7;97;40m-\033[m'*40)

    arqLog = open('logs.txt', 'a') #salva em arquivo cada teste
    arq = open('ips.txt', 'r')
    linha = arq.readline()
    while linha != '':
        partes = linha.split(';')
        tempo = ver_media(partes[0])
        funcao = ver_media(partes[1])

        agora = datetime.now()
        dia = agora.strftime('%d/%m/%Y')
        hora = agora.strftime('%H:%M:%S')
        print(f'\033[7;97;40m{partes[0]:25s} {tempo}\033[m')
        arqLog.write(partes[0]+';'+str(tempo)+';'+dia+';'+hora+'\n')

        linha = arq.readline()
    arq.close()
    arqLog.close()
####################################################


def logs():
    titulo('\033[7;97;40m         Listagem de Logs           \033[m')
    arq = open('logs.txt', 'r')
    print('\033[7;97;40mNº..: IP / Dominio............: Média (ms): Dia do accesso..: Hora..:\033[m')
    num = 0
    linha = arq.readline()

    while linha != '':
        num = num + 1
        partes = linha.split(';')
        ip = str(partes[0])
        tempo = str(partes[1])
        dia = str(partes[2])
        hora = str(partes[3])
        print(f'\033[7;97;40m{num:3d} {ip:30s} {tempo:3s}      {dia:17s} {hora} \033[m', end='')
        linha = arq.readline()
    arq.close()
    print('-'*43)
    print('\033[7;97;40m -> Se o tempo em ms, for igual a\033[m \033[1;31m-1\033[m,\033[7;97;40m\n'
          ' o host não está respondendo\033[m')
    return


######################### programa principal
while True:
    print('\033[7;97;40m=\033[m' * 43)
    print('''\033[3;30;44m#### Selecione uma Opção: ####\033[m \033[7;97;40m
    1.  Listar Ips 
    2.  Testar
    3.  Log de testes
    4.  Finalizar 
\033[m\n ''')
    print('\033[7;97;40m=\033[m' * 43)
    opcao = int(input('\033[3;30;44mDigite sua opção:\033[m '))
    if opcao == 1:
        listar()
    elif opcao == 2:
        testar()
    elif opcao == 3:
        logs()
    elif opcao == 4:
        calcula()
    elif opcao == 5:
        print('\033[1;30mPrograma Finalizado pelo Usuário!!!\n'
              '==//==//==//==//==//==//==//==//==//\033[m')
        exit()
    else:
        print('\033[1;31mOps...\n'
              ' Opção Inválida!!!\033[m')
        break

 

Edited by edmin
incluir o arquivo de ips

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By Juliana dos Santos
      Oi gente, 
       
      Eu tenho uma tabela no banco de dados do snowflake que é atualizada por um flat file que é atualizado a cada quinze dias; Sempre que os dados são atualizados nesse flat file ele sobrescreve as informações anteriores e assim não temos histórico dos dados que estavam no banco antes da ultima atualização, isso esta causando uma dor de cabeça por que sempre que ocorre algum erro não temos como voltar para o resultado anterior e o flat file tem que ser refeito por algum analista.
       
      As configurações do banco de dados foram feitas em Sql, enquanto o esquema que rodam para jogar as informações do flat file para a tabela do banco esta em python.
       
      Eu acabei de chegar a essa área e herdei essa criança e tenho pensado em como resolve-lo e criar uma nova tabela que não sobrescreva mas sim empilhe as informações, porem existe uma grande pegadinha nesse processo, esse flat file é atualizado muitas vezes até que ele chegue a sua "versão final" que é utilizada para o fechamento, esse fechamento que não acontece sempre no mesmo dia. Para que o histórico seja confiável ele não pode empilhar os dados toda vez que atualizarmos, apenas quando realmente for fechado.
       
      Vocês conseguem me ajudar? O que devo fazer? Criar um fluxo com algum trigger? mudar a forma que o flat file é alimentado?
       
      Me ajudem a enxergar algum caminho para resolver o que foi criado antes da minha chegada
       
      Desde já agradeço,
      Um beijo e um queijo.
       
      Ju
    • By Hyroshima
      Boa noite pessoal, não sei se meu problema está relacionado com a categoria mas não achei outro local melhor ;/
      Eu fiz algumas buscas mas talvez posso estar procurando errado por quê não achei nada que respondesse minha dúvida.
      Eu queria saber se é possível enviar um comando de teclado sem teclado pelo ssh, resumindo eu queria por exemplo executar o comando de teclado Ctrl+B e logo depois a tecla o via terminal, tipo o comando pyautogui.hotkey('ctrl','f5') do python, ou nesse caso eu teria que usar o python para executar esses comandos?
       
      desde já obrigado pela atenção.
    • By Dcdbbvb
      Faça um código que deverá ter uma matriz de qualquer tamanho(Você define o tamanho) no qual o usuário irá digitar os números que serão armazenados na matriz. Construa uma função que deverá somar todos os números digitados. No final o programa mostrará a matriz e o valor total da somatória.
       
      por favorrrr alguém me ajuda
    • By Marcos Vilela Alves
      Bom dia. Iniciei em Python há algumas semanas.  não tive problemas até o momento.
       
      Estou desenvolvendo um projeto Python desktop utilizando qtDesigner e Pyqt5. 
      O conflito que tive não encontrei solução.
       
      Tenho um login, que funciona e abre a "tela principal".
      a tela principal tem vários menus. Meu problema agora aparece.
      Eu criei uma tela para gerenciar permissões, porem quando eu clico para abir a tela, ela abre, porém bloqueada.
       
      eu só consigo mexer nela, depois que fecho a principal. 
      Nao encontrei na internet nenhuma referência.
       
      Segue os códigos.
      Tela Principal
      import sys from principal import Ui_principal from PyQt5 import QtCore, uic from PyQt5.QtWidgets import QMainWindow, QApplication from loginAuth import * from permissoes import Ui_Permissoes class form_principal(QMainWindow,Ui_principal): def __init__(self, parent=None): super().__init__(parent) super().setupUi(self) self.mnuSair.triggered.connect(self.Sair) self.mnuPermissoesAcesso.triggered.connect(self.abrePermissoes) def abrePermissoes(self): from form_permissoes import form_permissoes self.per = form_permissoes() self.per.setWindowFlags(QtCore.Qt.WindowStaysOnTopHint) # AlwaysOnTop self.per.show() self.per.setEnabled(True) # tentativa de forcar o habilitar ##Form permissoes import sys from principal import Ui_principal from PyQt5 import QtCore, uic from PyQt5.QtWidgets import QFrame, QMainWindow, QApplication, QDialog from loginAuth import * from fpermissoes import Ui_Frame class form_permissoes (QFrame, Ui_Frame): def __init__(self, parent=None): super().__init__(parent) super().setupUi(self)  
      o arquivo que contem os componentes do formulario é o abaixo, que foi criado pelo QtDesiner e convertido usando o commando pyuic5
      from PyQt5 import QtCore, QtGui, QtWidgets class Ui_Frame(object): def setupUi(self, Frame): Frame.setObjectName("Frame") Frame.resize(619, 300) self.groupBox = QtWidgets.QGroupBox(Frame) self.groupBox.setGeometry(QtCore.QRect(10, 10, 591, 261)) self.groupBox.setObjectName("groupBox") self.treeWidget = QtWidgets.QTreeWidget(self.groupBox) self.treeWidget.setGeometry(QtCore.QRect(10, 20, 571, 231)) self.treeWidget.setObjectName("treeWidget") item_0 = QtWidgets.QTreeWidgetItem(self.treeWidget) item_1 = QtWidgets.QTreeWidgetItem(item_0) item_2 = QtWidgets.QTreeWidgetItem(item_1) item_3 = QtWidgets.QTreeWidgetItem(item_2) item_3 = QtWidgets.QTreeWidgetItem(item_2) self.retranslateUi(Frame) QtCore.QMetaObject.connectSlotsByName(Frame) def retranslateUi(self, Frame): _translate = QtCore.QCoreApplication.translate Frame.setWindowTitle(_translate("Frame", "Permissões")) self.groupBox.setTitle(_translate("Frame", "Menus")) self.treeWidget.headerItem().setText(0, _translate("Frame", "Menus")) __sortingEnabled = self.treeWidget.isSortingEnabled() self.treeWidget.setSortingEnabled(False) self.treeWidget.topLevelItem(0).setText(0, _translate("Frame", "Arquivo")) self.treeWidget.topLevelItem(0).child(0).setText(0, _translate("Frame", "Cadastro")) self.treeWidget.topLevelItem(0).child(0).child(0).setText(0, _translate("Frame", "Solos")) self.treeWidget.topLevelItem(0).child(0).child(0).child(0).setText(0, _translate("Frame", "PH")) self.treeWidget.topLevelItem(0).child(0).child(0).child(1).setText(0, _translate("Frame", "M.O")) self.treeWidget.setSortingEnabled(__sortingEnabled)  
      Como eu disse, a tela abre, mas como se estivesse bloqueada.

       
       
       
    • By lotthaus
      Alguém poderia fazer essa atividade para eu ajudar um amigo ?

×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.