在linux中使用Python将文件写入U盘?
我在写入文件时遇到了比预期多得多的麻烦。我有一台小型单板计算机,运行在带有Angstrom嵌入式发行版的arm处理器上。我正在用python为它编写一个应用程序。应用程序应该检测U盘,然后将文件转储到U盘。我遇到的问题是,即使我的脚本似乎正确地写入了文件,并且文件在Linux中使用“ls”和“cat”显示在那里,当我取出U盘并尝试在Windows或其他Linux发行版中查看文件时,它仍然是空的,或者更常见的情况是根本不存在。我的应用程序是多线程的。我创建/media/mymntpnt作为根目录 感谢您的帮助 以下是我的一些代码片段: 这一部分是我用来识别U盘的:在linux中使用Python将文件写入U盘?,python,linux,file,usb-drive,Python,Linux,File,Usb Drive,我在写入文件时遇到了比预期多得多的麻烦。我有一台小型单板计算机,运行在带有Angstrom嵌入式发行版的arm处理器上。我正在用python为它编写一个应用程序。应用程序应该检测U盘,然后将文件转储到U盘。我遇到的问题是,即使我的脚本似乎正确地写入了文件,并且文件在Linux中使用“ls”和“cat”显示在那里,当我取出U盘并尝试在Windows或其他Linux发行版中查看文件时,它仍然是空的,或者更常见的情况是根本不存在。我的应用程序是多线程的。我创建/media/mymntpnt作为根目录
class MediaScanner():
def __init__(self):
self.lok = thread.allocate_lock()
self.running = True
self.started = False
def register_cb(self,func):
self.cb = func
def start(self):
if not self.started:
thread.start_new_thread(self.scan_thread,())
def scan_thread(self):
self.quit = False
self.started = True
last_devices = []
while self.running:
devices = self.scan_media()
if (devices != last_devices):
self.cb(devices) #call the callback as its own thread
last_devices = devices
time.sleep(0.1)
self.quit = True
def stop(self):
self.running = False
while(not self.quit):
pass
return True
def is_running(self):
return self.running
def scan_media(self):
with self.lok:
partitionsFile = open("/proc/partitions")
lines = partitionsFile.readlines()[2:]#Skips the header lines
devices = []
for line in lines:
words = [x.strip() for x in line.split()]
minorNumber = int(words[1])
deviceName = words[3]
if minorNumber % 16 == 0:
path = "/sys/class/block/" + deviceName
if os.path.islink(path):
if os.path.realpath(path).find("/usb") > 0:
devices.append('/dev/'+deviceName)
partitionsFile.close()
return devices
下面是我编写文件的脚本示例:
from mediascanner import *
from util import *
from database import *
from log import *
ms = MediaScanner()
devices = ms.scan_media()
print devices
if devices:
db = TestDatabase(init_tables=False)
data = db.get_all_test_data()
for device in devices:
print device
mount_partition(get_partition(device))
write_and_verify('/media/mymntpnt/test_'+get_log_file_name(),flatten_tests(data))
unmount_partition()
以下是我的实用功能:
def write_and_verify(f_n,data):
f = file(f_n,'w')
f.write(data)
f.flush()
f.close()
f = file(f_n,'r')
verified = f.read()
f.close()
return verified == data and f.closed
def get_partition(dev):
os.system('fdisk -l %s > output' % dev)
f = file('output')
data = f.read()
print data
f.close()
return data.split('\n')[-2].split()[0].strip()
def mount_partition(partition):
os.system('mount %s /media/mymntpnt' % partition)
def unmount_partition():
os.system('umount /media/mymntpnt')
错误出现在write函数中,它应该在关闭文件之前同步文件,如下所示。读取总是成功的,因为数据已经在RAM中。您可能需要尝试不同的方法来验证它,例如检查字节数
def write_and_verify(f_n,data):
f = file(f_n,'w')
f.write(data)
f.flush()
os.fsync(f.fileno())
f.close()
f = file(f_n,'r')
verified = f.read()
f.close()
return verified == data and f.closed
如果您得到这样的文件信息
finfo=os.stat(f_n)
,那么您可以将finfo.st_size
与预期写入的字节数进行比较。错误在于写入函数,该函数应在关闭文件之前同步文件,如下所示。读取总是成功的,因为数据已经在RAM中。您可能需要尝试不同的方法来验证它,例如检查字节数
def write_and_verify(f_n,data):
f = file(f_n,'w')
f.write(data)
f.flush()
os.fsync(f.fileno())
f.close()
f = file(f_n,'r')
verified = f.read()
f.close()
return verified == data and f.closed
如果您得到这样的文件信息
finfo=os.stat(f_n)
,那么您可以将finfo.st_size
与预期写入的字节数进行比较。您是否尝试过sync
和/或pmount
和pumount
?这有点像头脑风暴。再看看os.fdatasync
(在linux上可能相当于os.system('fsync…
),所以有时候你确实会在你的计算机上看到该文件。umount
是否总是成功的?检查返回值。由于您的应用程序是多线程的,因此可能是分区正忙,无法卸载。只是猜测……这个问题与Python没有什么关系。由于性能问题,操作系统正在缓存数据,而不是将数据写入U盘。您必须确保卸载驱动器已成功完成。您是否尝试过sync
和/或pmount
和pumount
?这有点像头脑风暴。再看看os.fdatasync
(在linux上可能相当于os.system('fsync…
),所以有时候你确实会在你的计算机上看到该文件。umount
是否总是成功的?检查返回值。由于您的应用程序是多线程的,因此可能是分区正忙,无法卸载。只是猜测……这个问题与Python没有什么关系。由于性能问题,操作系统正在缓存数据,而不是将数据写入U盘。您必须确保卸载驱动器已成功完成。