我正在尝试从网络位置打开.csv文件并遇到以下错误..我有以下问题
1.如何在Windows中打开网络位置
2.如何在windows和linux中打开相同的网络位置?
import csv
import datetime
from collections import deque
#from collections import maxlength
icount=9
now = datetime.datetime.now()
time =now.strftime("%m/%d/%Y")
#Keep appending date and count everytime this script is run
c = csv.writer(open("\\data\loc\\scripts\trend.csv", "ab"))
c.writerow([time, icount-1])
#Now read the recent 5 entries and print
#cr = csv.reader(open("trend.csv","rb"))
with open('trend.csv','rU') as fin:
reader=csv.reader(fin)
d=deque(reader,8)
for l in d:
print l[0]
print l[1]
错误: -
Traceback (most recent call last):
File "database.py", line 10, in <module>
c = csv.writer(open("\\data\loc\scripts\trend.csv", "ab"))
IOError: [Errno 2] No such file or directory: '\\data\loc\\scripts\trend.csv'
答案 0 :(得分:1)
你的第一个问题是:
c = csv.writer(open("\\data\loc\\scripts\trend.csv", "ab"))
因为你没有逃避反斜杠,\t
变成一个标签,每个\\
变成一个反斜杠,而\l
你很幸运,它没有变化。所以,这就是你要求的道路:
\data\loc\scripts rend.csv
显然那里什么也没有。
始终对Windows路径使用原始字符串,您将不会遇到此问题。
c = csv.writer(open(r"\\data\loc\\scripts\trend.csv", "ab"))
假设有一个名为data
且名为loc
的共享的SMB服务器,您已经登录,现在可以使用。
你应该在scripts
之前摆脱额外的反斜杠,并且总是关闭你打开的文件......但这些都不会导致你的问题。
从Linux中,你不能像这样使用UNC路径访问SMB共享。
有两种常见的方法。
首先,您可以将SMB共享安装在文件系统的某个位置。如果您已将smb://data/loc
挂载到/mnt/data-loc
,那么您需要写的就是:
c = csv.writer(open(r"/mnt/data-loc/scripts/trend.csv", "ab"))
或者,您可以直接访问SMB,有点像处理FTP服务器。如果你search PyPI,你会找到各种各样的Python库来简化这一过程。其中许多需要libsmbclient
库,smbclient
工具或其他您可能未安装的工具,因此请务必阅读要求。以下是您使用其中一个库的方法:
import smbclient
smb = smbclient.SambaClient(server='DATA', share='LOC', domain='WORKGROUP',
username='me', password='swordfish')
smb.chdir('scripts')
with smb.open('trend.csv', 'rb') as f:
data = f.read()
sio = StringIO.StringIO(data)
c = csv.writer(sio)
c.writerow([time, icount-1])
with smb.open('trend.csv', 'wb') as f:
f.write(sio.getvalue())
smb.close()