It's always worth stepping through the actions you are trying to perform
using manual commands when you can. What you're doing with the lines
> ws.Cells.Copy
> ws.[A1].PasteSpecial Paste:=xlValues
is to overwrite the source cells with their values, as far as I can see.
Now, if you have a filter on, then this is going to fail. Specifically,
Excel will report that the selection is not valid for one of several
reasons. The applicable one would be "Copy and paste areas cannot overlap
unless they're the same size and shape".
Your copy selection is the filtered area (i.e. there are rows that aren't
included in the copy). Your paste area, A1 and auto extended down, is
probably all consecutive rows, including those that are filtered out. Or
perhaps it's the area from A1 down to where the first filtered row is. It's
difficult to see. But it's the wrong size anyway.
If you really need to handle filtered worksheet, then you probably have a
bit of fiddling to do, assuming you want to retain manual row heights. I
suspect you need to get your code to do the following:
- Make a copy of the whole sheet, so as to include column widths and manual
row heights.
- Select the used cells in the copy and delete their rows. (Not that you
would only need to do this if you had manual row heights.) If all rows are
auto fit, then you can simply delete the cell contents instead.
- Select the used cells in the original and copy them to the copy (note
"paste" not "paste special"). This should get just the visible rows across,
complete with their formatting and manual row heights.
- Select the used cells in the copy (not filtered here), and do your paste
special, etc, and then put the copy into the e-mail.
- Discard the copy worksheet.
You'll need to do a bit of trial and error to get the right procedure
working here. You can experiment with manual actions, and then simply
record it to a macro and copy the code out.
There is an added benefit with this, of leaving your source sheet with its
formulas, etc, intact, so it is less destructive than pasting in place.
Regards, Dave S
----- Original Message -----
From: "sspatriots" <sspatriots@yahoo.com>
To: <ExcelVBA@yahoogroups.com>
Sent: Friday, September 02, 2011 11:42 PM
Subject: [ExcelVBA] Send Current Worksheet to Outlook
> Hi,
>
> I have the code below that I use with a 'Ctrl+t' shortcut to automatically
> place a copy of my current worksheet (values only) into a new e-mail as an
> attachment. I went to use it this morning and it doesn't seem to like the
> following line when I try and use it having a filtered column.
>
> ws.[A1].PasteSpecial Paste:=xlValues
>
> I tried adding a few lines telling it to select only visible cells, but
> that ended up not being the issue, because when I use Debug, it keeps
> pointing me back to the line of code above.
>
> Any help fixing this to work with filtered columns would be greatly
> appreciated.
>
> Thanks,
>
> Steve
>
>
>
> Sub EmailWithOutlook()
> 'Variable declaration
> Dim strMyName As String
> Dim ws As Worksheet
> Dim oApp As Object, _
> oMail As Object, _
> WB As Workbook, _
> FileName As String
> strMyName = ActiveSheet.Name
>
> 'Turn off screen updating
> Application.ScreenUpdating = False
>
> 'Make a copy of the active sheet and save it to
> 'a temporary file
> ActiveSheet.Copy
>
> For Each ws In ActiveWorkbook.Worksheets
> ws.Cells.Copy
>
> ws.[A1].PasteSpecial Paste:=xlValues
> ws.Cells.Hyperlinks.Delete
> Application.CutCopyMode = False
> Cells(1, 1).Select
> ws.Activate
> ws.Name = strMyName & " (" & Format(Date, "mmddyy") & ")"
> Next ws
>
>
>
> Set WB = ActiveWorkbook
> FileName = strMyName & ".xlsx"
> On Error Resume Next
> Kill "C:\" & FileName
> On Error GoTo 0
> WB.SaveAs FileName:="C:\" & FileName
>
> 'Create and show the outlook mail item
> Set oApp = CreateObject("Outlook.Application")
> Set oMail = oApp.CreateItem(0)
> With oMail
> 'Uncomment the line below to hard code a recipient
> '.To = "someone@somedomain.com"
> 'Uncomment the line below to hard code a subject
> '.Subject = "Look at my workbook!"
> .Attachments.Add WB.FullName
> .Display
> End With
>
> 'Delete the temporary file
> WB.ChangeFileAccess Mode:=xlReadOnly
> Kill WB.FullName
> WB.Close SaveChanges:=False
>
> 'Restore screen updating and release Outlook
> Application.ScreenUpdating = True
> Set oMail = Nothing
> Set oApp = Nothing
> End Sub
>
>
>
> ------------------------------------
>
> ----------------------------------
> Be sure to check out TechTrax Ezine for many, free Excel VBA articles! Go
> here: http://www.mousetrax.com/techtrax to enter the ezine, then search
> the ARCHIVES for EXCEL VBA.
>
> ----------------------------------
> Visit our ExcelVBA group home page for more info and support files:
> http://groups.yahoo.com/group/ExcelVBA
>
> ----------------------------------
> More free tutorials and resources available at:
> http://www.mousetrax.com
>
> ----------------------------------Yahoo! Groups Links
>
>
>
>
>
> -----
> No virus found in this message.
> Checked by AVG - www.avg.com
> Version: 10.0.1392 / Virus Database: 1520/3871 - Release Date: 09/01/11
>
Be sure to check out TechTrax Ezine for many, free Excel VBA articles! Go here: http://www.mousetrax.com/techtrax to enter the ezine, then search the ARCHIVES for EXCEL VBA.
----------------------------------
Visit our ExcelVBA group home page for more info and support files:
http://groups.yahoo.com/group/ExcelVBA
----------------------------------
More free tutorials and resources available at:
http://www.mousetrax.com
----------------------------------
Tidak ada komentar:
Posting Komentar