ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

是否可以使用python获取Pendrive的挂载点并知道其序列号?

2019-11-20 18:56:07  阅读:229  来源: 互联网

标签:usb-drive serial-number linux windows python


我有2台PC(Linux和Windows)连接到位于不同楼层的本地网络.该楼层的人们将其USB笔式驱动器连接到任意一台PC,我想将不同的特定文件集复制给不同的人.

先前,

>我所做的事情是如此艰辛(坐在地板上并手动完成)
>后来我写了一个python程序,将特定的文件集复制到
我通过SSH决定的特定人员. (即.我登录到
通过ssh的特定计算机,要求用户(通过电话)一个接一个地插入他们的
笔式驱动器,然后我执行接受一个
论点.这个论点不过是我想复制的名字,
并通过接收自变量,程序决定要存储的文件
复制到随身碟).
这个过程仍然有点乏味,..
因为只能连接一个笔式驱动器,所以我不得不为每个用户重复执行此操作.

为了减少总时间,我在两个系统上都连接了USB集线器,以便在给定时间内多次插入笔式驱动器.问题来了,决定哪个设备属于谁.

问题:是否可以使用python从SerialNumber中找到笔式驱动器的安装点? (如果使用python,那就太好了,因为主程序是用python编写的)

我正在考虑SerialNumber的原因,

> UUID-格式化设备时更改
>供应商,ProdID和制造商-不确定是否会
不同. (即,如果来自同一制造商和同一制造商
模型)

我在Windows上尝试了wmi ..并从SO中获得了此代码,(对不起,我没有链接.很久以前就拿来了)

import win32com.client

wmi = win32com.client.GetObject ("winmgmts:")
for usb in wmi.InstancesOf ("Win32_USBHub"):
    print usb.DeviceID

我得到的输出是

USB\VID_5986&PID_0292\6&4817B6D&0&6
USB\VID_8087&PID_0024\5&55D1EEC&0&1
USB\VID_8087&PID_0024\5&88B8ABA&0&1
USB\ROOT_HUB20\4&11F77F7&0
USB\ROOT_HUB20\4&62BF53D&0
USB\VID_03F0&PID_3307\JN0W5LAB0ZHQ5VK8

它与linux中类似的情况,我只能使用usb设备获得序列号.但是无法获得其相应的挂载点

任何想法请…

解决方法:

为此,在Linux上,您需要解析/ proc / mounts以确定设备名称到安装点的映射,即/ dev / sdc2-> / var / run / media / myaut / hyperx.

诀窍是找出需要序列号的设备名称.最简单的方法是使用udev-在/ dev / disk / by-id中生成符号链接时使用串行:

/dev/disk/by-id/usb-Generic_Flash_Disk_12345678-0:0 -> ../../sdd

但是我们没有寻求最简单的解决方案,对吗?诀窍是可以更改udev规则,并且sysfs(来自内核)更可靠.我实现了一个脚本来做到这一点:

import os
import sys
import glob

SYS_USB_DEVICES = '/sys/bus/usb/devices'
SYS_BLOCK_DEVICES = '/sys/class/block'

try:
    serial = sys.argv[1]
except IndexError:
    print >> sys.stderr, "Usage: findflash.py SERIAL"
    sys.exit(1)

# PASS 1 Find USB node with corresponding to serial

for usbid in os.listdir(SYS_USB_DEVICES):
    usbserpath = os.path.join(SYS_USB_DEVICES, usbid, 'serial')    
    if not os.path.exists(usbserpath):
        continue    
    with open(usbserpath) as f:
        usb_serial = f.read().strip()

    if serial == usb_serial:
        # Found it!
        break
else:
    print >> sys.stderr, "Cannot find usb device with serial {0}".format(serial)
    sys.exit(1)

# Find SCSI ids corresponding to this device
# I didn't check SYSFS documentation, but tested it on openSUSE 13.1
# The form of path is:
#   <SUBDEVICE>/host<SCSI_HOST_ID>/target<SCSI_TARGET_ID>/<CTRL><CHANNEL>:<TGT>:<LUN>
# We need only basename

devs = glob.glob(os.path.join(SYS_USB_DEVICES, usbid, 
                            '*/host*/target*/*:*:*:*'))

devs = map(os.path.basename, devs)

# PASS 2 - find mountpoints for devices with SCSI ids we discover earlier

# Parse mountpoint formatted as "/dev/... /path/to/mntpt ..." 
def parse_mntpt(line):
    dev, mntpt, _ = line.split(None, 2)
    dev = os.path.basename(dev)
    return dev, mntpt

mntpts = {}
with open('/proc/mounts') as f:
    mntpts = dict(map(parse_mntpt, f.readlines()))

# List of ('scsi id', 'dev name', 'mnt pt (if exists)')
devlist = []

def create_dev(scsiid, devname):
    global mntpts
    devlist.append((scsiid, devname, mntpts.get(devname)))

for devname in os.listdir(SYS_BLOCK_DEVICES):
    devpath = os.path.join(SYS_BLOCK_DEVICES, devname)
    devlink = os.path.join(devpath, 'device')

    # Node is "virtual", i.e. partition, ignore it
    if not os.path.islink(devlink):
        continue

    scsiid = os.path.basename(os.readlink(devlink))    
    if scsiid not in devs:
        continue

    create_dev(scsiid, devname)

    # Find partition names
    parts = glob.glob(os.path.join(devpath, '*/partition'))

    for partpath in parts:
        partname = os.path.basename(os.path.dirname(partpath))
        create_dev(scsiid, partname)

# END - print results
fmtstr = '{0:8} {1:5} {2}'
print fmtstr.format('SCSI ID', 'DEV', 'MOUNT POINT')
for scsiid, devname, mntpt in devlist:
    print fmtstr.format(scsiid, devname, mntpt)

这是示例输出:

$python findflash.py 12345678
SCSI ID  DEV   MOUNT POINT
8:0:0:0  sdd   None
8:0:0:0  sdd1  /var/run/media/myaut/Debian\040wheezy\04020140723-17:30
8:0:0:0  sdd2  None
8:0:0:0  sdd5  None
8:0:0:1  sr0   None

我不能说在Windows上那么容易.我有一个代码(在C / WinAPI中),能够从系统收集所有磁盘设备,但是其逻辑与文件系统表示相去甚远,因此我仍然没有找到解决方案.

Windows的复杂性来自于:

>诸如SetupDi *之类的功能可以让您枚举磁盘设备.它们的名称采用PnP样式,与卷名无关.
>有DOS风格的API(即在A:和C:级别上工作)
>有WinNT风格的API,它知道卷以及可能的挂载点.

当然,将三层链接起来并不明显(有一种方法可以通过分区的大小/偏移来匹配分区,但这很疯狂).我仍然不敢在我的图书馆中实现它:(

标签:usb-drive,serial-number,linux,windows,python
来源: https://codeday.me/bug/20191120/2046290.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有