OfficeTips Home || VBA Section || General Section ||  Download Section  ||  Privacy Policy

Change A Link In A Formula Without Changing The Formula

This can be done with the INDIRECT function by creating a concatenated string with input from several worksheet cells which contain workbook (in A1) and worksheet (in B1) names. 
 
=INDIRECT("'["&A1&"]"&B1&"'!A1")
 
Unfortunately, this type of formula will only work if the referenced workbook is OPEN. Now the INDEX function can return a linked cell value from a hard-coded link range. For example, if you define a range as "Reference1", where the linked range formula is:
 
=[Book1.xls]Sheet1!$1:$65536 

then you can use the formula:
 
=IF(ISERR(INDEX(Reference1,ROW(),COLUMN())),"",INDEX(Reference1,ROW(),COLUMN()))
 
in any cell and the returned value will be from the same cell in Book1.xls on Sheet1. Then, variable links to this formula can be made by changing the  link range as referred to in a named formula. This formula is of the form:
 
=CHOOSE(Sheet2!$A$1-29*INT((Sheet2!$A$1-1)/29),Reference1,Reference2,...,Reference29)
 
where Sheet2!$A$1 is an input cell for values from 1 to n which represent  a particular link stored as a defined name. As you are probably aware, the CHOOSE can only accept 29 arguments.  This technique can be extended to handle up to 841 (29x29) links.
 
Note: This technique works great as long as the linked files are not moved, renamed or deleted.
 
 

Copyright 1999-2022 (c) Shyam Pillai. All rights reserved.