Linux7.3默认的python系统是2.7.5,然后想着升级使用python3.6.6

1 下载

2 解压  tar fx Python-3.6.6.tgz

3  configure --prefix=/usr/local/python3.6

4 make && make install

5 ln -s /usr/local/python3.6/bin/python3.6  /usr/bin/python3.6

说明:这里是让两个版本的python共存

下面的脚本成功执行的

# /usr/bin/env python3.6
# -*- coding: utf-8 -*- import time
import subprocess
import re
from concurrent.futures import ThreadPoolExecutor def ping_call(ip):
command = 'ping -c 2 -W 1 %s' % ip
print(command)
file = open('/dev/null', 'w')
result = subprocess.call(command,
shell=True, stdout=file, stderr=file)
print(result)
if result:
print('ip-address {} ping fail'.format(ip))
else:
print('ip-address {} ping ok'.format(ip))
success.append(ip.split('.')[-1])
file.close() if __name__ == '__main__':
network = input('please input network>>>').strip()
host = input('please input your host range>>>').strip().split()
a, b = host[0], host[1]
print(network.split('.'))
if len(network.split('.')) == 3 and a.isdigit() and b.isdigit() and re.match('\d{1,3}\.\d{1,3}\.\d{1,3}', network):
a, b = int(a), int(b)
pool = ThreadPoolExecutor(50)
start_time = time.time()
success = []
for i in range(a, b + 1):
ret = pool.submit(ping_call, network + "." + str(i))
pool.shutdown()
print("multi_Thread spend-time {:.2f}".format(time.time() - start_time))
print("passed host is: ")
print(success)

说明:但是始终有个问题:不能使用中文,使用中文就报错,百度多次,暂时不明原因

使用中文报错:

UnicodeEncodeError 'ascii' codec can't encode characters in position

找到问题根源了:输入和输出编码的问题

[root@centos7 ~]# python3.6
Python 3.6.6 (default, Sep 1 2018, 17:07:25)
[GCC 4.8.5 20150623 (Red Hat 4.8.5-11)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import sys
>>> sys.stdout.encoding
'ANSI_X3.4-1968'
>>> sys.stdin.encoding
'ANSI_X3.4-1968'
>>>

所以使用前加入PYTHONIOENCODING=utf-8

中文版:

# /usr/bin/env python3.6
# -*- coding: utf-8 -*- import time
import subprocess
import re
from concurrent.futures import ThreadPoolExecutor def ping_call(ip):
command = 'ping -c 2 -W 1 %s' % ip
print(command)
file = open('/dev/null', 'w')
result = subprocess.call(command,
shell=True, stdout=file, stderr=file)
print(result)
if result:
print('ip地址: {} ping fail'.format(ip))
else:
print('ip地址: {} ping ok'.format(ip))
success.append(ip.split('.')[-1])
file.close() if __name__ == '__main__':
network = input('请输入 网段>>>').strip()
host = input('请输入主机范围,空格隔开>>>').strip().split()
a, b = host[0], host[1]
print(network.split('.'))
if len(network.split('.')) == 3 and a.isdigit() and b.isdigit() and re.match('\d{1,3}\.\d{1,3}\.\d{1,3}', network):
a, b = int(a), int(b)
pool = ThreadPoolExecutor(50)
start_time = time.time()
success = []
for i in range(a, b + 1):
ret = pool.submit(ping_call, network + "." + str(i))
pool.shutdown()
print("multi_Thread spend-time {:.2f}".format(time.time() - start_time))
print("passed host is: ")
print(success)

执行:与python2的方式不一样

[root@centos7 ~]# PYTHONIOENCODING=utf-8 python3.6 ping_host3.6.py
请输入 网段>>>192.168.0
请输入主机范围,空格隔开>>>1 10
['', '', '']
ping -c 2 -W 1 192.168.0.1
ping -c 2 -W 1 192.168.0.2
0
ip地址: 192.168.0.1 ping ok
ping -c 2 -W 1 192.168.0.3
ping -c 2 -W 1 192.168.0.4
ping -c 2 -W 1 192.168.0.5
ping -c 2 -W 1 192.168.0.6
ping -c 2 -W 1 192.168.0.7
ping -c 2 -W 1 192.168.0.8
ping -c 2 -W 1 192.168.0.9
ping -c 2 -W 1 192.168.0.10
0
ip地址: 192.168.0.2 ping ok
1
ip地址: 192.168.0.3 ping fail
1
ip地址: 192.168.0.4 ping fail
1
ip地址: 192.168.0.5 ping fail
1
ip地址: 192.168.0.6 ping fail
1
ip地址: 192.168.0.7 ping fail
1
ip地址: 192.168.0.8 ping fail
1
ip地址: 192.168.0.9 ping fail
1
ip地址: 192.168.0.10 ping fail
multi_Thread spend-time 2.09
passed host is:
['', '']

最后去掉提示改为一行命令版

# /usr/bin/env python3.6
# -*- coding: utf-8 -*- import time
import subprocess
import re
import sys
import os
from concurrent.futures import ThreadPoolExecutor def ping_call(ip):
command = 'ping -c 2 -W 1 %s' % ip
print(command)
file = open('/dev/null', 'w')
result = subprocess.call(command,
shell=True, stdout=file, stderr=file)
if result:
print('ip地址: {} ping fail'.format(ip))
else:
print('ip地址: {} ping ok'.format(ip))
success.append(ip.split('.')[-1])
file.close() if __name__ == '__main__':
# network = input('请输入 网段>>>').strip()
network = sys.argv[1]
# host = input('请输入主机范围,空格隔开>>>').strip().split()
a, b = sys.argv[2], sys.argv[3]
print(network.split('.'))
if len(network.split('.')) == 3 and a.isdigit() and b.isdigit() and re.match('\d{1,3}\.\d{1,3}\.\d{1,3}', network):
a, b = int(a), int(b)
pool = ThreadPoolExecutor(50)
start_time = time.time()
success = []
for i in range(a, b + 1):
ret = pool.submit(ping_call, network + "." + str(i))
pool.shutdown()
print("花费的时间: {:.2f}".format(time.time() - start_time))
print("能ping通的主机有: ")
for i in success:
print(i, end='\t')
print()

Linux7.3系统 升级python到3.6使用ping主机脚本的更多相关文章

  1. 【Linux】CentOS下升级Python和Pip版本全自动化py脚本

    [Linux]CentOS下升级Python和Pip版本全自动化py脚本 CentOS7.6自带py2.7和py3.6 想要安装其它版本的话就要自己重新下载和编译py其它版本并且配置环境,主要是软链接 ...

  2. 升级 python 2.6.6 系统到 2.7.10 版本

    CentOS 6 系统默认 Python 版本是:2.6.6 平时在使用中遇到很多的库要求是 2.7.x 版本的库,比如使用 ConfigParser 库,在 2.6 版本库就不支持没有 value ...

  3. Linux系统下升级Python版本步骤(suse系统)

    Linux系统下升级Python版本步骤(suse系统) http://blog.csdn.net/lifengling1234/article/details/53536493

  4. linux centos系统下升级python版本

    本文参考资料:https://www.cnblogs.com/leon-zyl/p/8422699.html,https://blog.csdn.net/tpc1990519/article/deta ...

  5. CentOS6 系统下升级python后yum命令使用时报错

    CentOS6 系统下升级python后yum命令使用时报错,如下: [root@xxxxxxx]#yumFile"/usr/bin/yum",line30exceptKeyboa ...

  6. Linux 下编译升级 Python

    一.Centos下升级python3.4.3 1.下载安装 wget http://www.python.org/ftp/python/3.4.3/Python-3.4.3.tgz wget http ...

  7. CentOS 6.5升级Python和安装IPython

    <转自:http://www.noanylove.com/2014/10/centos-6-5-sheng-ji-python-he-an-zhuang-ipython/>自己常用.以做备 ...

  8. Linux下升级python版本

    转载自:http://lovebeyond.iteye.com/blog/1770476 CentOS下的Python版本一般都比较低,很多应用都需要升级python来完成.我装的centOS的默认的 ...

  9. CentOS 6.5升级Python后yum不可用的解决方案

    因开发需要,今天把CentOS 6.5自带的Python2.6.6升级到了Python2.7.3.按照如下步骤进行升级 1.查看当前系统python的版本 python -V 2.下载2.7.3版本的 ...

随机推荐

  1. ML: 聚类算法R包-对比

    测试验证环境 数据: 7w+ 条,数据结构如下图: > head(car.train) DV DC RV RC SOC HV LV HT LT Type TypeName 1 379 85.09 ...

  2. oracle中delete、truncate、drop的区别

    oracle中delete.truncate.drop的区别 标签: deleteoracletable存储 2012-05-23 15:12 7674人阅读 评论(0) 收藏 举报  分类: ora ...

  3. InfluxDB HTTP API reference

    InfluxDB HTTP API reference API地址:https://docs.influxdata.com/influxdb/v1.6/tools/api/ The InfluxDB ...

  4. SpringCloud之实现客户端的负载均衡Ribbon(二)

    一 Ribbon简介 Ribbon是Netflix发布的负载均衡器,它有助于控制HTTP和TCP的客户端的行为.为Ribbon配置服务提供者地址后,Ribbon就可基于某种负载均衡算法,自动地帮助服务 ...

  5. ALGO-39_蓝桥杯_算法训练_数组排序去重

    问题描述 输入10个整数组成的序列,要求对其进行升序排序,并去掉重复元素. 输入格式 10个整数. 输出格式 多行输出,每行一个元素. 样例输入 样例输出 解题思路: 若输入的数字存在数组中,剔除,否 ...

  6. C++进阶--不让编译器自动生成类函数

    //############################################################################ /* * 不让编译器自动生成类函数 * * ...

  7. 【Mysql+shell】查询结果导出到文件,文件数据导入到数据库

    Shell: 执行Mysql查询,并将查询结果导出到文件 直接使用Mysql执行查询 mysql> use xxx_dbName; mysql> select * from log_06 ...

  8. hadoop-n.x.y.tar.gz、hadoop-n.x.y.tar.gz.asc 、hadoop-n.x.y.tar.gz.md5 、hadoop-n.x.y.tar.gz.mds分别是什么?

    不多说,直接上干货! 我这里,以hadoop-2.6.0为例. hadoop-n.x.y.tar.gz.mds,此mds文件是为了检验在下载和移动文件过程中文件的完整性. 通过验证文件的md5值去检验 ...

  9. 让HTMLrunner 报告的子列表都 默认展示出来的 方法(方便发送邮件时可以方便查看)

    1.找到生成的测试报告,获取到all元素 2.在HTMLrunner源码,</script> 标签上 加入一个函数 #让所有列表都展示出来window.onload = function ...

  10. Java-Runoob-高级教程-实例-数组:16. Java 实例 - 数组并集

    ylbtech-Java-Runoob-高级教程-实例-数组:16. Java 实例 - 数组并集 1.返回顶部 1. Java 实例 - 数组并集  Java 实例 以下实例演示了如何使用 unio ...