Home |
Search |
Today's Posts |
|
#1
![]()
Posted to microsoft.public.excel.programming
|
|||
|
|||
![]()
My workbook is named Scorecard, and its worksheets are
entitled Scorecard, Customer, Finance, and Employee. When the user clicks the Save icon, I want the cursor in each worksheet to be placed in Cell A1, and the worksheet named Scorecard to be the the last worksheet changed. The object is that when a another user first opens the Workbook, the worksheet named Scorecard comes up first, and as each of the other worksheets is opened, it shows the top of the worksheet - thus the force of cursor to cell A1. Thanks, Phil |
#2
![]()
Posted to microsoft.public.excel.programming
|
|||
|
|||
![]()
Phil,
If, as you say, you want a standard set-up when the user "opens" the workbook, a simple way would be as follows: Sub Auto_Open() Application.ScreenUpdating = False Worksheets("Employee").Activate Range("A1").Activate Worksheets("Customer").Activate Range("A1").Activate Worksheets("Finance").Activate Range("A1").Activate Worksheets("Scorecard").Activate Range("A1").Activate Application.ScreenUpdating = True End Sub The above macro, when placed in a regular module, will run whenever the workbook is opened and insure that "Scorecard" is the active sheet and that cell "A1" is the active cell on all the sheets. John Phil Hageman wrote: My workbook is named Scorecard, and its worksheets are entitled Scorecard, Customer, Finance, and Employee. When the user clicks the Save icon, I want the cursor in each worksheet to be placed in Cell A1, and the worksheet named Scorecard to be the the last worksheet changed. The object is that when a another user first opens the Workbook, the worksheet named Scorecard comes up first, and as each of the other worksheets is opened, it shows the top of the worksheet - thus the force of cursor to cell A1. Thanks, Phil |
#3
![]()
Posted to microsoft.public.excel.programming
|
|||
|
|||
![]()
John, Thanks for your reply. I copy/pasted the code into
the "This Workbook" module, but it doesn't work. There is no error message to hint of the problem either. Is there something I should look for? Thanks, Phil -----Original Message----- Phil, If, as you say, you want a standard set-up when the user "opens" the workbook, a simple way would be as follows: Sub Auto_Open() Application.ScreenUpdating = False Worksheets("Employee").Activate Range("A1").Activate Worksheets("Customer").Activate Range("A1").Activate Worksheets("Finance").Activate Range("A1").Activate Worksheets("Scorecard").Activate Range("A1").Activate Application.ScreenUpdating = True End Sub The above macro, when placed in a regular module, will run whenever the workbook is opened and insure that "Scorecard" is the active sheet and that cell "A1" is the active cell on all the sheets. John Phil Hageman wrote: My workbook is named Scorecard, and its worksheets are entitled Scorecard, Customer, Finance, and Employee. When the user clicks the Save icon, I want the cursor in each worksheet to be placed in Cell A1, and the worksheet named Scorecard to be the the last worksheet changed. The object is that when a another user first opens the Workbook, the worksheet named Scorecard comes up first, and as each of the other worksheets is opened, it shows the top of the worksheet - thus the force of cursor to cell A1. Thanks, Phil . |
#4
![]()
Posted to microsoft.public.excel.programming
|
|||
|
|||
![]()
Or:
Sub Auto_Open() Application.ScreenUpdating = False Worksheets(Array("Employee", "Customer", "Finance", "Scorecard")).Select Range("A1").Select Worksheets("Scorecard").Select Application.ScreenUpdating = True End Sub Regards Trevor "John Wilson" wrote in message ... Phil, If, as you say, you want a standard set-up when the user "opens" the workbook, a simple way would be as follows: Sub Auto_Open() Application.ScreenUpdating = False Worksheets("Employee").Activate Range("A1").Activate Worksheets("Customer").Activate Range("A1").Activate Worksheets("Finance").Activate Range("A1").Activate Worksheets("Scorecard").Activate Range("A1").Activate Application.ScreenUpdating = True End Sub The above macro, when placed in a regular module, will run whenever the workbook is opened and insure that "Scorecard" is the active sheet and that cell "A1" is the active cell on all the sheets. John Phil Hageman wrote: My workbook is named Scorecard, and its worksheets are entitled Scorecard, Customer, Finance, and Employee. When the user clicks the Save icon, I want the cursor in each worksheet to be placed in Cell A1, and the worksheet named Scorecard to be the the last worksheet changed. The object is that when a another user first opens the Workbook, the worksheet named Scorecard comes up first, and as each of the other worksheets is opened, it shows the top of the worksheet - thus the force of cursor to cell A1. Thanks, Phil |
#5
![]()
Posted to microsoft.public.excel.programming
|
|||
|
|||
![]()
Trevor,
I need to "think" array more often. Your way makes it much cleaner and more straightforward. Thanx, John Trevor Shuttleworth wrote: Or: Sub Auto_Open() Application.ScreenUpdating = False Worksheets(Array("Employee", "Customer", "Finance", "Scorecard")).Select Range("A1").Select Worksheets("Scorecard").Select Application.ScreenUpdating = True End Sub Regards Trevor "John Wilson" wrote in message ... Phil, If, as you say, you want a standard set-up when the user "opens" the workbook, a simple way would be as follows: Sub Auto_Open() Application.ScreenUpdating = False Worksheets("Employee").Activate Range("A1").Activate Worksheets("Customer").Activate Range("A1").Activate Worksheets("Finance").Activate Range("A1").Activate Worksheets("Scorecard").Activate Range("A1").Activate Application.ScreenUpdating = True End Sub The above macro, when placed in a regular module, will run whenever the workbook is opened and insure that "Scorecard" is the active sheet and that cell "A1" is the active cell on all the sheets. John Phil Hageman wrote: My workbook is named Scorecard, and its worksheets are entitled Scorecard, Customer, Finance, and Employee. When the user clicks the Save icon, I want the cursor in each worksheet to be placed in Cell A1, and the worksheet named Scorecard to be the the last worksheet changed. The object is that when a another user first opens the Workbook, the worksheet named Scorecard comes up first, and as each of the other worksheets is opened, it shows the top of the worksheet - thus the force of cursor to cell A1. Thanks, Phil |
#6
![]()
Posted to microsoft.public.excel.programming
|
|||
|
|||
![]()
Trevpr and John,
Used the Array code - it puts the cursor in A1, and "Scorecard" is the active worksheet, but in all worksheets, the scroll does not put the document where A1 is visible. To test, I put the cursor at the end of each worksheet - that is what is visible when opening. Is there a scroll instruction to use? Phil -----Original Message----- Or: Sub Auto_Open() Application.ScreenUpdating = False Worksheets(Array ("Employee", "Customer", "Finance", "Scorecard")).Select Range("A1").Select Worksheets("Scorecard").Select Application.ScreenUpdating = True End Sub Regards Trevor "John Wilson" wrote in message ... Phil, If, as you say, you want a standard set-up when the user "opens" the workbook, a simple way would be as follows: Sub Auto_Open() Application.ScreenUpdating = False Worksheets("Employee").Activate Range("A1").Activate Worksheets("Customer").Activate Range("A1").Activate Worksheets("Finance").Activate Range("A1").Activate Worksheets("Scorecard").Activate Range("A1").Activate Application.ScreenUpdating = True End Sub The above macro, when placed in a regular module, will run whenever the workbook is opened and insure that "Scorecard" is the active sheet and that cell "A1" is the active cell on all the sheets. John Phil Hageman wrote: My workbook is named Scorecard, and its worksheets are entitled Scorecard, Customer, Finance, and Employee. When the user clicks the Save icon, I want the cursor in each worksheet to be placed in Cell A1, and the worksheet named Scorecard to be the the last worksheet changed. The object is that when a another user first opens the Workbook, the worksheet named Scorecard comes up first, and as each of the other worksheets is opened, it shows the top of the worksheet - thus the force of cursor to cell A1. Thanks, Phil . |
#7
![]()
Posted to microsoft.public.excel.programming
|
|||
|
|||
![]()
Trevpr and John,
Used the Array code - it puts the cursor in A1, and "Scorecard" is the active worksheet, but in all worksheets, the scroll does not put the document where A1 is visible. To test, I put the cursor at the end of each worksheet - that is what is visible when opening. Is there a scroll instruction to use? Phil -----Original Message----- Or: Sub Auto_Open() Application.ScreenUpdating = False Worksheets(Array ("Employee", "Customer", "Finance", "Scorecard")).Select Range("A1").Select Worksheets("Scorecard").Select Application.ScreenUpdating = True End Sub Regards Trevor "John Wilson" wrote in message ... Phil, If, as you say, you want a standard set-up when the user "opens" the workbook, a simple way would be as follows: Sub Auto_Open() Application.ScreenUpdating = False Worksheets("Employee").Activate Range("A1").Activate Worksheets("Customer").Activate Range("A1").Activate Worksheets("Finance").Activate Range("A1").Activate Worksheets("Scorecard").Activate Range("A1").Activate Application.ScreenUpdating = True End Sub The above macro, when placed in a regular module, will run whenever the workbook is opened and insure that "Scorecard" is the active sheet and that cell "A1" is the active cell on all the sheets. John Phil Hageman wrote: My workbook is named Scorecard, and its worksheets are entitled Scorecard, Customer, Finance, and Employee. When the user clicks the Save icon, I want the cursor in each worksheet to be placed in Cell A1, and the worksheet named Scorecard to be the the last worksheet changed. The object is that when a another user first opens the Workbook, the worksheet named Scorecard comes up first, and as each of the other worksheets is opened, it shows the top of the worksheet - thus the force of cursor to cell A1. Thanks, Phil . |
#8
![]()
Posted to microsoft.public.excel.programming
|
|||
|
|||
![]()
Phil,
Now I think I see what you're after. The following is the long way of doing this (I'm sure there's a more concise way), but it should do what you want: Sub Auto_Open() Application.ScreenUpdating = False Worksheets("Employee").Activate Range("A1").Activate Application.Goto ActiveCell, True Worksheets("Customer").Activate Range("A1").Activate Application.Goto ActiveCell, True Worksheets("Finance").Activate Range("A1").Activate Application.Goto ActiveCell, True Worksheets("Scorecard").Activate Range("A1").Activate Application.Goto ActiveCell, True Application.ScreenUpdating = True End Sub John Phil Hageman wrote: Trevpr and John, Used the Array code - it puts the cursor in A1, and "Scorecard" is the active worksheet, but in all worksheets, the scroll does not put the document where A1 is visible. To test, I put the cursor at the end of each worksheet - that is what is visible when opening. Is there a scroll instruction to use? Phil -----Original Message----- Or: Sub Auto_Open() Application.ScreenUpdating = False Worksheets(Array ("Employee", "Customer", "Finance", "Scorecard")).Select Range("A1").Select Worksheets("Scorecard").Select Application.ScreenUpdating = True End Sub Regards Trevor "John Wilson" wrote in message ... Phil, If, as you say, you want a standard set-up when the user "opens" the workbook, a simple way would be as follows: Sub Auto_Open() Application.ScreenUpdating = False Worksheets("Employee").Activate Range("A1").Activate Worksheets("Customer").Activate Range("A1").Activate Worksheets("Finance").Activate Range("A1").Activate Worksheets("Scorecard").Activate Range("A1").Activate Application.ScreenUpdating = True End Sub The above macro, when placed in a regular module, will run whenever the workbook is opened and insure that "Scorecard" is the active sheet and that cell "A1" is the active cell on all the sheets. John Phil Hageman wrote: My workbook is named Scorecard, and its worksheets are entitled Scorecard, Customer, Finance, and Employee. When the user clicks the Save icon, I want the cursor in each worksheet to be placed in Cell A1, and the worksheet named Scorecard to be the the last worksheet changed. The object is that when a another user first opens the Workbook, the worksheet named Scorecard comes up first, and as each of the other worksheets is opened, it shows the top of the worksheet - thus the force of cursor to cell A1. Thanks, Phil . |
#9
![]()
Posted to microsoft.public.excel.programming
|
|||
|
|||
![]()
John
a concise way ? ;-) Sure there's better (and probably shorter) Sub Auto_Open() Application.ScreenUpdating = False For Each ws In Worksheets ws.Select Application.Goto ws.Range("A1"), True Next Worksheets("Scorecard").Select Application.ScreenUpdating = True End Sub Regards Trevor "John Wilson" wrote in message ... Phil, Now I think I see what you're after. The following is the long way of doing this (I'm sure there's a more concise way), but it should do what you want: Sub Auto_Open() Application.ScreenUpdating = False Worksheets("Employee").Activate Range("A1").Activate Application.Goto ActiveCell, True Worksheets("Customer").Activate Range("A1").Activate Application.Goto ActiveCell, True Worksheets("Finance").Activate Range("A1").Activate Application.Goto ActiveCell, True Worksheets("Scorecard").Activate Range("A1").Activate Application.Goto ActiveCell, True Application.ScreenUpdating = True End Sub John Phil Hageman wrote: Trevpr and John, Used the Array code - it puts the cursor in A1, and "Scorecard" is the active worksheet, but in all worksheets, the scroll does not put the document where A1 is visible. To test, I put the cursor at the end of each worksheet - that is what is visible when opening. Is there a scroll instruction to use? Phil -----Original Message----- Or: Sub Auto_Open() Application.ScreenUpdating = False Worksheets(Array ("Employee", "Customer", "Finance", "Scorecard")).Select Range("A1").Select Worksheets("Scorecard").Select Application.ScreenUpdating = True End Sub Regards Trevor "John Wilson" wrote in message ... Phil, If, as you say, you want a standard set-up when the user "opens" the workbook, a simple way would be as follows: Sub Auto_Open() Application.ScreenUpdating = False Worksheets("Employee").Activate Range("A1").Activate Worksheets("Customer").Activate Range("A1").Activate Worksheets("Finance").Activate Range("A1").Activate Worksheets("Scorecard").Activate Range("A1").Activate Application.ScreenUpdating = True End Sub The above macro, when placed in a regular module, will run whenever the workbook is opened and insure that "Scorecard" is the active sheet and that cell "A1" is the active cell on all the sheets. John Phil Hageman wrote: My workbook is named Scorecard, and its worksheets are entitled Scorecard, Customer, Finance, and Employee. When the user clicks the Save icon, I want the cursor in each worksheet to be placed in Cell A1, and the worksheet named Scorecard to be the the last worksheet changed. The object is that when a another user first opens the Workbook, the worksheet named Scorecard comes up first, and as each of the other worksheets is opened, it shows the top of the worksheet - thus the force of cursor to cell A1. Thanks, Phil . |
Reply |
Thread Tools | Search this Thread |
Display Modes | |
|
|
![]() |
||||
Thread | Forum | |||
split post code (zip code) out of cell that includes full address | Excel Discussion (Misc queries) | |||
Code to conditional format all black after date specified in code? | Excel Discussion (Misc queries) | |||
Drop Down/List w/Code and Definition, only code entered when selec | Excel Worksheet Functions | |||
Convert a Number Code to a Text Code | Excel Discussion (Misc queries) | |||
Problem with Before_Save Macro | Excel Discussion (Misc queries) |