IOError:[Errno 2]访问Excel文件时没有这样的文件或目录

问题描述:

我正在调用保存在桌面上的python脚本的VBA代码。这是我的一块VBA代码。IOError:[Errno 2]访问Excel文件时没有这样的文件或目录

Shell "cmd /k C:\Python27\python.exe C:\Users\ashish.baboo\Desktop\UKT-SL-Ashish\Cleaning-Tools\Old-Geocode.py" 
waitTill = Now() + TimeValue("00:00:40") 
While Now() < waitTill 
DoEvents 

这个Python脚本在放置在桌面上的excel文件中加载地址。当我直接运行python脚本时,它执行完美。但是,当我运行VBA代码时,Python脚本打开,但给我一个错误,Excel文件不可用。这里是我的Python脚本代码:

import xlrd 
import geocoder 
import openpyxl 
from openpyxl import load_workbook 
location = "C:\\Users\\ashish.baboo\\Desktop\\UKT-SL-Ashish\\Cleaning-Tools\\1.xlsx" 
workbook = xlrd.open_workbook(location) 
sheet = workbook.sheet_by_index(1) 


Rows = sheet.nrows 
Cols = sheet.ncols 
data = [[sheet.cell_value(r,c) for c in range(Cols)] for r in range(Rows)] 

wb = load_workbook('1.xlsx') 
ws1 = wb.get_sheet_by_name("Locations") 


for i in range(1,Rows): 
    add = ws1.cell(row = i+1, column = 19).value 
    cadd = geocoder.google(add , language = "en" , key = "AIzaSyBsiH6LubuA9dn1s97UsUcesQRw71isBuo") 
    print(i , cadd.latlng , cadd.quality ,cadd.country) 
    S_no = ws1.cell(row = i+1, column = 1) 
    O_Housenumber = ws1.cell(row = i+1, column = 3) 
    O_Street = ws1.cell(row = i+1, column = 4) 
    O_City = ws1.cell(row = i+1, column = 5) 
    O_County = ws1.cell(row = i+1, column = 6) 
    O_State = ws1.cell(row = i+1, column = 7) 
    O_Postal = ws1.cell(row = i+1, column = 8) 
    O_Country = ws1.cell(row = i+1, column = 9) 
    Latitude = ws1.cell(row = i+1, column = 10) 
    Longitude = ws1.cell(row = i+1, column = 11) 
    Accuracy = ws1.cell(row = i+1, column = 12) 
    S_no.value = i 
    O_Housenumber.value = cadd.housenumber 
    O_Street.value = cadd.street 
    O_City.value = cadd.city 
    O_County.value = cadd.county 
    O_State.value = cadd.state_long 
    O_Postal.value = cadd.postal 
    O_Country.value = cadd.country_long 
    Latitude.value = cadd.lat 
    Longitude.value = cadd.lng 
    Accuracy.value = cadd.quality 

    wb.save('1.xlsx') 

我已经尝试了很多解决方案,但没有成功。请建议如何解决它?

+1

是你的VBA代码从python脚本尝试打开的文件运行吗? – avb

+0

@avb我没有得到你。但不是 。我的代码是在Outlook VBA中。所以它不在excel文件中,脚本正试图打开。 –

这条线:

wb = load_workbook('1.xlsx') 

依赖于程序知道到哪里寻找文件。如果你从VBA启动Python,那么工作目录几乎肯定会有所不同。所以你的Python程序需要知道完整的文件路径。您可以在程序中对其进行硬编码,也可以从命令行将它传递给程序。

+0

这是正确的答案。这解决了我的问题。谢谢 ! –