But a new version of the workbook was issued to users with some of the named range definitions missing. So to compensate for this, I added a correction table to the database with three text fields - FieldName, Sheet (e.g. "xyz") and Cell (e.g. "A5"). When the load routine fails to find the required field in the workbook, the following code segment was intended to retrieve the value from the workbook:
varData = wb.Sheets(rst!Sheet).Range(rst!Cell).Value
This failed with "Run-time error '13': Type mismatch". Subsequent testing in the immediate window showed the culprit to be accessing the Sheets collection with wb.Sheets(18).Name returning "xyz" but wb.Sheets("xyz").Name failing with Error 13.
I don't get this error from VBA running in the Excel client, only when Excel is an automation client and the code is running within the Access client. It also applies to the Worksheets collection as well (as you would expect).
The workaround was to change the correction table to be two fields - FieldName & RefersTo (which is Sheet and Cell combined e.g. "xyz!A5") and to use the following which works without any problems:
varData = appExcel.Range(rst!RefersTo).Value