python执行结果 返回结果回显

 方法一 os.system("cmd.exe")

返回结果错误分类:

执行成功,那么会返回0,表示命令执行成功。

"OS error code   1:  Operation not permitted"
 "OS error code   2:  No such file or directory"
 "OS error code   3:  No such process"
 "OS error code   4:  Interrupted system call"
 "OS error code   5:  Input/output error"
 "OS error code   6:  No such device or address"
 "OS error code   7:  Argument list too long"
 "OS error code   8:  Exec format error"
 "OS error code   9:  Bad file descriptor"
 "OS error code  10:  No child processes"
 "OS error code  11:  Resource temporarily unavailable"
 "OS error code  12:  Cannot allocate memory"
 "OS error code  13:  Permission denied"
 "OS error code  14:  Bad address"
 "OS error code  15:  Block device required"
 "OS error code  16:  Device or resource busy"
 "OS error code  17:  File exists"
 "OS error code  18:  Invalid cross-device link"
 "OS error code  19:  No such device"
 "OS error code  20:  Not a directory"
 "OS error code  21:  Is a directory"
 "OS error code  22:  Invalid argument"
 "OS error code  23:  Too many open files in system"
 "OS error code  24:  Too many open files"
 "OS error code  25:  Inappropriate ioctl for device"
 "OS error code  26:  Text file busy"
 "OS error code  27:  File too large"
 "OS error code  28:  No space left on device"
 "OS error code  29:  Illegal seek"
 "OS error code  30:  Read-only file system"
 "OS error code  31:  Too many links"
 "OS error code  32:  Broken pipe"
 "OS error code  33:  Numerical argument out of domain"
 "OS error code  34:  Numerical result out of range"
 "OS error code  35:  Resource deadlock avoided"
 "OS error code  36:  File name too long"
 "OS error code  37:  No locks available"
 "OS error code  38:  Function not implemented"
 "OS error code  39:  Directory not empty"
 "OS error code  40:  Too many levels of symbolic links"
 "OS error code  42:  No message of desired type"
 "OS error code  43:  Identifier removed"
 "OS error code  44:  Channel number out of range"
 "OS error code  45:  Level 2 not synchronized"
 "OS error code  46:  Level 3 halted"
 "OS error code  47:  Level 3 reset"
 "OS error code  48:  Link number out of range"
 "OS error code  49:  Protocol driver not attached"
 "OS error code  50:  No CSI structure available"
 "OS error code  51:  Level 2 halted"
 "OS error code  52:  Invalid exchange"
 "OS error code  53:  Invalid request descriptor"
 "OS error code  54:  Exchange full"
 "OS error code  55:  No anode"
 "OS error code  56:  Invalid request code"
 "OS error code  57:  Invalid slot"
 "OS error code  59:  Bad font file format"
 "OS error code  60:  Device not a stream"
 "OS error code  61:  No data available"
 "OS error code  62:  Timer expired"
 "OS error code  63:  Out of streams resources"
 "OS error code  64:  Machine is not on the network"
 "OS error code  65:  Package not installed"
 "OS error code  66:  Object is remote"
 "OS error code  67:  Link has been severed"
 "OS error code  68:  Advertise error"
 "OS error code  69:  Srmount error"
 "OS error code  70:  Communication error on send"
 "OS error code  71:  Protocol error"
 "OS error code  72:  Multihop attempted"
 "OS error code  73:  RFS specific error"
 "OS error code  74:  Bad message"
 "OS error code  75:  Value too large for defined data type"
 "OS error code  76:  Name not unique on network"
 "OS error code  77:  File descriptor in bad state"
 "OS error code  78:  Remote address changed"
 "OS error code  79:  Can not access a needed shared library"
 "OS error code  80:  Accessing a corrupted shared library"
 "OS error code  81:  .lib section in a.out corrupted"
 "OS error code  82:  Attempting to link in too many shared libraries"
 "OS error code  83:  Cannot exec a shared library directly"
 "OS error code  84:  Invalid or incomplete multibyte or wide character"
 "OS error code  85:  Interrupted system call should be restarted"
 "OS error code  86:  Streams pipe error"
 "OS error code  87:  Too many users"
 "OS error code  88:  Socket operation on non-socket"
 "OS error code  89:  Destination address required"
 "OS error code  90:  Message too long"
 "OS error code  91:  Protocol wrong type for socket"
 "OS error code  92:  Protocol not available"
 "OS error code  93:  Protocol not supported"
 "OS error code  94:  Socket type not supported"
 "OS error code  95:  Operation not supported"
 "OS error code  96:  Protocol family not supported"
 "OS error code  97:  Address family not supported by protocol"
 "OS error code  98:  Address already in use"
 "OS error code  99:  Cannot assign requested address"
 "OS error code 100:  Network is down"
 "OS error code 101:  Network is unreachable"
 "OS error code 102:  Network dropped connection on reset"
 "OS error code 103:  Software caused connection abort"
 "OS error code 104:  Connection reset by peer"
 "OS error code 105:  No buffer space available"
 "OS error code 106:  Transport endpoint is already connected"
 "OS error code 107:  Transport endpoint is not connected"
 "OS error code 108:  Cannot send after transport endpoint shutdown"
 "OS error code 109:  Too many references: cannot splice"
 "OS error code 110:  Connection timed out"
 "OS error code 111:  Connection refused"
 "OS error code 112:  Host is down"
 "OS error code 113:  No route to host"
 "OS error code 114:  Operation already in progress"
 "OS error code 115:  Operation now in progress"
 "OS error code 116:  Stale NFS file handle"
 "OS error code 117:  Structure needs cleaning"
 "OS error code 118:  Not a XENIX named type file"
 "OS error code 119:  No XENIX semaphores available"
 "OS error code 120:  Is a named type file"
 "OS error code 121:  Remote I/O error"
 "OS error code 122:  Disk quota exceeded"
 "OS error code 123:  No medium found"
 "OS error code 124:  Wrong medium type"
 "OS error code 125:  Operation canceled"
 "OS error code 126:  Required key not available"
 "OS error code 127:  Key has expired"
 "OS error code 128:  Key has been revoked"
 "OS error code 129:  Key was rejected by service"
 "OS error code 130:  Owner died"
 "OS error code 131:  State not recoverable"
————————————————
版权声明:本文为CSDN博主「lwgkzl」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/lwgkzl/article/details/81060016

 

方法二 #output = subprocess.check_output(ex, stderr=subprocess.STDOUT, shell=True)

 

y = subprocess.check_output(str('ipconfig'), stderr=subprocess.STDOUT, shell=True)
output=y.decode('cp936').encode('utf-8')

需要解码

大概的错误类型:

- AttributeError: 'str' object has no attribute 'decode'
 - UnicodeDecodeError: 'utf-8' codec can't decode byte 0xc5 in position 13: invalid continuation byte

大概的输出应该长这样

- C:\Users\DELL>E:\App\py_work_3.7\Web\socket\netcat\mycat_sever.py
b'\r\nWindows IP \xc5\xe4\xd6\xc3\r\n\r\n\r\n\xd2\xd4\xcc\xab\xcd\xf8\xca\xca\xc5\xe4\xc6\xf7 VirtualBox Host-Only Network:\r\n\r\n   \xc1\xac\xbd\xd3\xcc\xd8\xb6\xa8\xb5\xc4 DNS \xba\xf3\xd7\xba . . . . . . . : \r\n   \xb1\xbe\xb5\xd8\xc1\xb4\xbd\xd3 IPv6 \xb5\xd8\xd6\xb7. . . . . . . . : fe80::48cd:403c:b18c:b807%2\r\n   IPv4 \xb5\xd8\xd6\xb7 . . . . . . . . . . . . : 192.168.56.1\r\n   \xd7\xd3\xcd\xf8\xd1\xda\xc2\xeb  . . . . . . . . . . . . : 255.255.255.0\r\n   \xc4\xac\xc8\xcf\xcd\xf8\xb9\xd8. . . . . . . . . . . . . : \r\n\r\n\xce\xde\xcf\xdf\xbe\xd6\xd3\xf2\xcd\xf8\xca\xca\xc5\xe4\xc6\xf7 WLAN:\r\n\r\n   \xc3\xbd\xcc\xe5\xd7\xb4\xcc\xac  . . . . . . . . . . . . : \xc3\xbd\xcc\xe5\xd2\xd1\xb6\xcf\xbf\xaa\xc1\xac\xbd\xd3\r\n   \xc1\xac\xbd\xd3\xcc\xd8\xb6\xa8\xb5\xc4 DNS \xba\xf3\xd7\xba . . . . . . . : \r\n\r\n\xce\xde\xcf\xdf\xbe\xd6\xd3\xf2\xcd\xf8\xca\xca\xc5\xe4\xc6\xf7 \xb1\xbe\xb5\xd8\xc1\xac\xbd\xd3* 1:\r\n\r\n   \xc3\xbd\xcc\xe5\xd7\xb4\xcc\xac  . . . . . . . . . . . . : \xc3\xbd\xcc\xe5\xd2\xd1\xb6\xcf\xbf\xaa\xc1\xac\xbd\xd3\r\n   \xc1\xac\xbd\xd3\xcc\xd8\xb6\xa8\xb5\xc4 DNS \xba\xf3\xd7\xba . . . . . . . : \r\n\r\n\xce\xde\xcf\xdf\xbe\xd6\xd3\xf2\xcd\xf8\xca\xca\xc5\xe4\xc6\xf7 \xb1\xbe\xb5\xd8\xc1\xac\xbd\xd3* 11:\r\n\r\n   \xc3\xbd\xcc\xe5\xd7\xb4\xcc\xac  . . . . . . . . . . . . : \xc3\xbd\xcc\xe5\xd2\xd1\xb6\xcf\xbf\xaa\xc1\xac\xbd\xd3\r\n   \xc1\xac\xbd\xd3\xcc\xd8\xb6\xa8\xb5\xc4 DNS \xba\xf3\xd7\xba . . . . . . . : \r\n\r\n\xd2\xd4\xcc\xab\xcd\xf8\xca\xca\xc5\xe4\xc6\xf7 \xd2\xd4\xcc\xab\xcd\xf8:\r\n\r\n   \xc1\xac\xbd\xd3\xcc\xd8\xb6\xa8\xb5\xc4 DNS \xba\xf3\xd7\xba . . . . . . . : \r\n   \xb1\xbe\xb5\xd8\xc1\xb4\xbd\xd3 IPv6 \xb5\xd8\xd6\xb7. . . . . . . . : fe80::2c17:be54:7db6:f701%12\r\n   IPv4 \xb5\xd8\xd6\xb7 . . . . . . . . . . . . : 192.168.1.104\r\n   \xd7\xd3\xcd\xf8\xd1\xda\xc2\xeb  . . . . . . . . . . . . : 255.255.255.0\r\n   \xc4\xac\xc8\xcf\xcd\xf8\xb9\xd8. . . . . . . . . . . . . : 192.168.1.1\r\n'

中文全部变成了特定编码,而数字和英文不受影响

原理1

image.png

原理2

在windows中通过subprocess调用cmd命令行,命令中包含中文是很令人头痛的事。由于cmd控制台用的是gbk编码,而python用的是utf-8。utf-8的字符串,在gbk编码的控制台上运行,当然会运行不了。假如再要你兼容繁体版的windows,此时更麻烦了。还好python提供了本地化接口
本地化

>>> import locale
>>> locale.getdefaultlocale()
('zh_CN', 'cp936')123

示例

import locale
cmd = cmd.encode(locale.getdefaultlocale()[1])
subprocess.Popen(cmd)

作者:w妙音
来源:CSDN
原文:https://blog.csdn.net/wyongqing/article/details/70410999?utm_source=copy
版权声明:本文为博主原创文章,转载请附上博文链接!

↑ 这个我没看太明白 不过还好还有一个例子↓

import subprocess
import sys
cmd = "cmd.exe"
begin = 101
end = 102
while begin < end:
    ##blow for windows shell chinese show##
    #reload(sys)
    #sys.setdefaultencoding('utf-8')
    print "excution result start :\n"
    child = subprocess.Popen(cmd, shell=True, stdout=subprocess.PIPE, stdin=subprocess.PIPE, stderr=subprocess.PIPE)
    print "ping -n 1 -w 100 192.168.1." + str(begin) + "\n"
    child.stdin.write("ping -n 1 -w 100 192.168.1." + str(begin) + "\n")
    child.stdin.close()
    child.wait()
    print "excution result end:\n"
    begin += 1
    #print child.stdout.readlines()
    for line in child.stdout.readlines():
        ##blow for pycharm and cygwin show chinese#
        output = line.decode('cp936').encode('utf-8')
        print "%s\n" % output

例子看不看都行,最重要的一句是

output = line.decode('cp936').encode('utf-8')

我在用完这一句后就神清气爽了↓

def run_command(ex):
    output = ''
    try:
        output = subprocess.check_output(ex, stderr=subprocess.STDOUT, shell=True)
    except:
        print("error")
    # print(output)
    out = output.decode('cp936').encode('utf-8')
    return out


作者:三秋树eyh
链接:https://www.jianshu.com/p/2f92f0eefec0
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

windows控制台与IDE编码兼容优化

在windows中通过subprocess调用cmd命令行,命令中包含中文是很令人头痛的事。由于cmd控制台用的是gbk编码,而python用的是utf-8。utf-8的字符串,在gbk编码的控制台上运行,当然会运行不了。假如再要你兼容繁体版的windows,此时更麻烦了。还好python提供了本地化接口

本地化
>>> import locale
>>> locale.getdefaultlocale()
('zh_CN', 'cp936')
1
2
3
示例
import locale
cmd = cmd.encode(locale.getdefaultlocale()[1])
subprocess.Popen(cmd)
————————————————
版权声明:本文为CSDN博主「w妙音」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/wyongqing/article/details/70410999

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要实现在 Python 中并发执行回显信息并且不乱,可以使用多线程或异步编程的方式。 使用多线程,可以创建多个线程并发执行任务,每个线程负责处理一个任务。通过使用线程锁来控制线程之间的访问,确保回显信息不乱。 使用异步编程,可以使用 async/await 关键字来定义异步函数,并使用 asyncio 库来执行异步任务。在异步函数中,可以使用 await 关键字来等待异步操作完成,然后返回结果。通过使用 asyncio 库的协程机制来控制任务的执行,确保回显信息不乱。 不论是多线程还是异步编程,都需要注意线程安全和同步机制,避免出现多个线程同时访问同一资源而引起的竞争条件和不一致问题。 ### 回答2: 在Python中,可以使用多线程或异步编程的方式实现并发执行回显信息不乱的效果。 1. 多线程: 使用多线程可以实现并发执行任务的效果,可以使用python内置的threading模块来创建和管理多线程。在多线程中,每个线程可以独立运行,通过共享变量来保持回显信息的顺序。 示例代码如下: ```python import threading def echo(message): print(message) threads = [] messages = ["Hello", "World", "Python"] for message in messages: t = threading.Thread(target=echo, args=(message,)) threads.append(t) t.start() for t in threads: t.join() ``` 运行上述代码,可以发现回显信息按照顺序打印出来。 2. 异步编程: 使用异步编程可以实现非阻塞的并发执行效果,可以使用python的asyncio模块来编写异步代码。通过使用async和await关键字来定义异步函数,可以确保回显信息按照顺序进行处理。 示例代码如下: ```python import asyncio async def echo(message): print(message) messages = ["Hello", "World", "Python"] async def main(): tasks = [] for message in messages: task = asyncio.create_task(echo(message)) tasks.append(task) await asyncio.gather(*tasks) asyncio.run(main()) ``` 运行上述代码,可以发现回显信息按照顺序打印出来。 无论是多线程还是异步编程,都可以实现并发执行回显信息不乱的效果,具体选择哪种方式,取决于具体的需求和场景。 ### 回答3: 在Python中,并发执行回显信息可以使用多线程或者异步编程的方式来实现。下面分别介绍两种方式: 1. 多线程:在Python中,可以使用`threading`模块来进行多线程编程。通过创建多个线程来同时执行回显信息的任务。 ```python import threading def echo_message(message): print(message) # 创建多个线程并执行回显任务 threads = [] for i in range(5): t = threading.Thread(target=echo_message, args=("Hello, World!",)) threads.append(t) t.start() # 等待所有线程执行结束 for t in threads: t.join() ``` 2. 异步编程:在Python 3.7及以上版本中,可以使用`asyncio`模块来进行异步编程。通过`async`和`await`关键字来定义异步函数,然后使用`asyncio`库提供的事件循环来并发执行任务。 ```python import asyncio async def echo_message(message): print(message) # 定义任务列表 tasks = [] for i in range(5): tasks.append(echo_message("Hello, World!")) # 创建事件循环并并发执行任务 loop = asyncio.get_event_loop() results = loop.run_until_complete(asyncio.gather(*tasks)) loop.close() ``` 以上两种方式都可以实现并发执行回显信息的任务,保证信息不乱。通过多线程可以使用多个线程同时执行任务,而异步编程则能够在单个线程内实现并发执行任务的效果,提高程序执行效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值