Home |
Search |
Today's Posts |
#6
![]()
Posted to microsoft.public.excel.programming
|
|||
|
|||
![]()
On Feb 13, 7:47*am, Mike H wrote:
Hi, To get this into a loop you need to rethink your sheet naming convention in the receieving workbook. For example you have Sheets("Sat") Sheets("Sat (2)") Sheets("Sat (3)") etc I hope it's a typo and your first sheet is actually Sheets("Sat (1)") If you change your first sheet to that then a loop is easy and this does the same work as all your code. Sub CombineSat() Windows("Consolidated Worksheet.xls").Activate For x = 1 To 12 Workbooks("combined sheets.xls").Sheets("Sat (" & x & ")").Range("F6:F11").Copy Range("AC4").Offset(, x).PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _ :=False, Transpose:=False Next End Sub Mike "pwk" wrote: I am putting together a workbook that consolidates quarterly sales from many departments by day of week so they may bee seen and averaged by day of week on one worksheet. The following macro put together for Saturday does it very well for five departments but its way too lengthy. Is there a way of paring it down to something more manageable? I have many more departments and days to insert and writing this is tedious. The macro I’m using is below. Also, where do I place Application.CutCopyMode = False to clear the clipboard? The weeks vary from 9-12 depending on the calendar. Thanks for your help in advance; I’ve learned a lot from you guys. Sub CombineSat() On Error GoTo EndOfMacro 'Week Number '1 * * Windows("combined sheets.xls").Activate * * Sheets("Sat").Select * * Range("F6:F11").Select * * Selection.Copy * * Windows("Consolidated Worksheet.xls").Activate * * Range("AD4").Select * * Selection.PasteSpecial Paste:=xlPasteValues '2 * * Windows("combined sheets.xls").Activate * * Sheets("Sat (2)").Select * * Range("F6:F11").Select * * Selection.Copy * * Windows("Consolidated Worksheet.xls").Activate * * Range("AE4").Select * * Selection.PasteSpecial Paste:=xlPasteValues '3 * * Windows("combined sheets.xls").Activate * * Sheets("Sat (3)").Select * * Range("F6:F11").Select * * Selection.Copy * * Windows("Consolidated Worksheet.xls").Activate * * Range("AF4").Select * * Selection.PasteSpecial Paste:=xlPasteValues '4 * * Windows("combined sheets.xls").Activate * * Sheets("Sat (4)").Select * * Range("F6:F11").Select * * Selection.Copy * * Windows("Consolidated Worksheet.xls").Activate * * Range("AG4").Select * * Selection.PasteSpecial Paste:=xlPasteValues '5 * * Windows("combined sheets.xls").Activate * * Sheets("Sat (5)").Select * * Range("F6:F11").Select * * Selection.Copy * * Windows("Consolidated Worksheet.xls").Activate * * Range("AH4").Select * * Selection.PasteSpecial Paste:=xlPasteValues '6 * * Windows("combined sheets.xls").Activate * * Sheets("Sat (6)").Select * * Range("F6:F11").Select * * Selection.Copy * * Windows("Consolidated Worksheet.xls").Activate * * Range("AI4").Select * * Selection.PasteSpecial Paste:=xlPasteValues '7 * * Windows("combined sheets.xls").Activate * * Sheets("Sat (7)").Select * * Range("F6:F11").Select * * Selection.Copy * * Windows("Consolidated Worksheet.xls").Activate * * Range("AJ4").Select * * Selection.PasteSpecial Paste:=xlPasteValues '8 * * Windows("combined sheets.xls").Activate * * Sheets("Sat (8)").Select * * Range("F6:F11").Select * * Selection.Copy * * Windows("Consolidated Worksheet.xls").Activate * * Range("AK4").Select * * Selection.PasteSpecial Paste:=xlPasteValues '9 * * Windows("combined sheets.xls").Activate * * Sheets("Sat (9)").Select * * Range("F6:F11").Select * * Selection.Copy * * Windows("Consolidated Worksheet.xls").Activate * * Range("AL4").Select * * Selection.PasteSpecial Paste:=xlPasteValues '10 * * Windows("combined sheets.xls").Activate * * Sheets("Sat (10)").Select * * Range("F6:F11").Select * * Selection.Copy * * Windows("Consolidated Worksheet.xls").Activate * * Range("AM4").Select * * Selection.PasteSpecial Paste:=xlPasteValues '11 * * Windows("combined sheets.xls").Activate * * Sheets("Sat (11)").Select * * Range("F6:F11").Select * * Selection.Copy * * Windows("Consolidated Worksheet.xls").Activate * * Range("AN4").Select * * Selection.PasteSpecial Paste:=xlPasteValues '12 * * Windows("combined sheets.xls").Activate * * Sheets("Sat (12)").Select * * Range("F6:F11").Select * * Selection.Copy * * Windows("Consolidated Worksheet.xls").Activate * * Range("AO4").Select * * Selection.PasteSpecial Paste:=xlPasteValues EndOfMacro: Exit Sub End Sub- Hide quoted text - - Show quoted text - Rather than rewrite this code for each day Mon thru Sat Is there a way to 'plug in' the day to replace Sat in the remaining macros? Thinking about it, I bet you knew was going to ask that. Thanks a lot. Paul I hope I posted this correctly. |
Thread Tools | Search this Thread |
Display Modes | |
|
|
![]() |
||||
Thread | Forum | |||
Cannot print both-sided by selecting multiple worksheets | Excel Discussion (Misc queries) | |||
Selecting Yes in data validation for multiple cells | Excel Discussion (Misc queries) | |||
Trouble with selecting multiple ranges of data | Excel Worksheet Functions | |||
Selecting/Adding data from Multiple Worksheets | Excel Discussion (Misc queries) | |||
Selecting and copying data from mutiple worksheets | Excel Discussion (Misc queries) |