Replace Window.Activate > Sheet.Select > Range.Select with a single command?

d0rian

Active Member
Joined
May 30, 2015
Messages
313
Office Version
  1. 365
Forgive my noob Q, but I'm mostly self-taught :/

I want to go to a 2nd open workbook, go to a specific sheet within that workbook, and select a specific range on that sheet. I currently use 3 lines:

Windows("data_file.xlsm").Activate
Sheets("raw_data").Select
Range("control_range").Select

That can't be all that efficient...though it's my understanding that I can't SELECT the control_range range unless the sheet it's on is active.

So is there a 1-line command I can use to tell Excel to go to a specific range on a 2nd open workbook?
 

Excel Facts

Ambidextrous Undo
Undo last command with Ctrl+Z or Alt+Backspace. If you use the Undo icon in the QAT, open the drop-down arrow to undo up to 100 steps.
If you need to select the range, try
Code:
Workbooks("data_file.xlsm").Activate
Application.Goto Sheets("raw_data").Range("control_range"), True
However if you just want to copy the range you can use
Code:
Workbooks("data_file.xlsm").Sheets("raw_data").Range("control_range").Copy
 
Upvote 0
Thank you -- what does the "True" argument in the first snippet do exactly?

Also, while we're on the topic, I don't quite understand why I can't Copy a range that's not on the currently-active sheet. Like imagine there were only 1 workbook open, and I wanted to Copy a range that wasn't on the active sheet, it seems like I'd still need to include the entire Workbooks("data_file.xlsm").Sheets("raw_data").Range("control_range").Copy path in the code...which just strikes me as odd because I can use a name ONCE to define a range...e.g. in my example, my workbook can only have a single range named "control_range", so why do I have to specify the full Workbooks/Sheets/Range path when there's no risk of ambiguity?

(I've also noticed that only SOME functions have this limitation...for example, I can use ClearContents on a range that's not on the active sheet, but Copy doesn't work, which again seemed odd.)
 
Upvote 0
what does the "True" argument in the first snippet do exactly?
Means that the window will scroll to the specified range, otherwise the range will be selected but it might not be in view.

With named ranges, if the scope is to the sheet you can do
Code:
Sheets("Page1B").Range("Header").Copy ActiveCell
However if it's scope is Workbook you can do
Code:
Range("Header").Copy ActiveCell
 
Upvote 0

Forum statistics

Threads
1,225,635
Messages
6,186,128
Members
453,340
Latest member
Stu61

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top