我一直在四处寻找,这让我很兴奋...这在C#很容易:/ /
无论如何..我找到了这个代码,这是我得到的最接近的代码,但是我对正则表达式感到厌烦,所以如果有人可以为我缩小代码,那么它只隔离每个设备的设备ID,那就是太棒了!无论如何,这是代码:
import re
import subprocess
device_re = re.compile("Bus\s+(?P<bus>\d+)\s+Device\s+(?P<device>\d+).+ID\s(?P<id> \w+:\w+)\s(?P<tag>.+)$", re.I)
df = subprocess.check_output("lsusb", shell=True)
devices = []
for i in df.split('\n'):
if i:
info = device_re.match(i)
if info:
dinfo = info.groupdict()
dinfo['device'] = '/dev/bus/usb/%s/%s' % (dinfo.pop('bus'), dinfo.pop('device'))
devices.append(dinfo)
print devices
答案 0 :(得分:1)
尝试这种方式:
import re
import subprocess
device_re = re.compile("Bus\s+(?P<bus>\d+)\s+Device\s+(?P<device>\d+).+ID\s(?P<id>\w+:\w+)\s(?P<tag>.+)$", re.I)
df = subprocess.check_output("lsusb", shell=True)
for i in df.split('\n'):
if i:
info = device_re.match(i)
if info:
dinfo = info.groupdict()
# Uncomment if you wish tags too
#print dinfo.pop('tag')
print dinfo.pop('id')
答案 1 :(得分:1)
以下代码仅为您提供设备ID。
import pprint
import subprocess
df = subprocess.check_output('lsusb', shell=True)
device_ids = []
for line in filter(lambda s: s.startswith('Bus'), df.split('\n')):
businfo, id, _ = line.split(':')
id = id.split()[1]
device_ids.append(id)
pprint.pprint(device_ids)