Hi,
i have this code for converting a webpge into an excel document, then i can apply a bunch of autofilters on the copied data to manipulate it...i am fairly new to VBA, but using this project as a way to learn it...
i have an issue with warning messages....the one at the moment is with when i am defining last row.....originally there was one lastrow dimension, but created 2, 1 for each sheet, as that was giving me an error. that error then dissappeared and replaced it with
"object variable or with block variable not set"
i have 2 sheets, both named as sheets, and as VBA objects as SI and TR (this way i don't have to keep writing sheets("SI") everytime), SI is where the raw webpage goes to to get converted, then i extract the filtered data, paste it into the sheet TR which is the cover, and will e used by people....code is as follows:
I've already been advised that i haven't put in Dim SI as Worksheet, and after "set SI = sheets("SI") for both sheets respectively, however when i added these it comes up with another error saying "duplicate declaration in current scope"
If anyone can help it would be much appreciated. This needs to work on excel 2010, but I created the sheet on excel 2013 (I use 2010 at work but 2013 at home. due to my job I can't take my stuff home)
data:image/s3,"s3://crabby-images/a0dd6/a0dd67a17ec8b6e6bcb45d7047f3d9bfe87084bb" alt="Smile :) :)"
i have this code for converting a webpge into an excel document, then i can apply a bunch of autofilters on the copied data to manipulate it...i am fairly new to VBA, but using this project as a way to learn it...
i have an issue with warning messages....the one at the moment is with when i am defining last row.....originally there was one lastrow dimension, but created 2, 1 for each sheet, as that was giving me an error. that error then dissappeared and replaced it with
"object variable or with block variable not set"
i have 2 sheets, both named as sheets, and as VBA objects as SI and TR (this way i don't have to keep writing sheets("SI") everytime), SI is where the raw webpage goes to to get converted, then i extract the filtered data, paste it into the sheet TR which is the cover, and will e used by people....code is as follows:
Code:
[/COLOR][COLOR=#333333]Sub filter_test()[/COLOR]
<code style="margin: 0px; padding: 0px; font-style: inherit; font-weight: inherit; line-height: 12px;">
Application.ScreenUpdating = False
SI.Visible = True
'all dimensions
Dim FilterStartDate As Date, FilterEndDate As Date
Dim lastrowsi As Long
Dim lastrowtr As Long
Dim FilterRange As Range
Dim trdrng As Range
Dim TRFRng As Range
Dim sh As Shape
Dim paidOUTrng As Range
Dim paidINrng As Range
'all range sets
Set trdrng = TR.Range("A" & (lastrowttr + 1))
Set TRFRng = TR.Range("a" & (lastrowtr + 1) & ":f" & (lastrowtr + 1))
SI.Activate
SI.Cells.Delete
SI.Range("A1").PasteSpecial
ActiveWindow.ScrollRow = 1
ActiveWindow.ScrollColumn = 1
ActiveSheet.paste
Application.CutCopyMode = False
' delete first 4 columns
SI.Columns("A:D").EntireColumn.Delete
'unmerge all cells
SI.Cells.UnMerge
'delete all shapes
For Each sh In SI.Shapes
sh.Delete
Next sh
'delete last columns
SI.Columns("G:L").EntireColumn.Delete
'autofilter all useful data by dates
With SI
lastrowsi = Cells.Find(What:="*", After:=Range("A1"), SearchOrder:=xlByRows, SearchDirection:=xlPrevious).Row
End With
With TR
lastrowtr = Cells.Find(What:="*", After:=Range("A1"), SearchOrder:=xlByRows, SearchDirection:=xlPrevious).Row
End With
Set FilterRange = SI.Range("A1:f" & lastrowsi)
FilterStartDate = TR.Range("tDate").Value
FilterEndDate = TR.Range("dfltedate").Value
FilterRange.AutoFilter field:=1, Criteria1:="<" & CDbl(FilterStartDate), _
Operator:=xlAnd, Criteria2:=">" & CDbl(FilterEndDate)
'copy usefull data to main spreadsheet under active stuff
ActiveSheet.UsedRange.SpecialCells(xlCellTypeVisible).Copy _
Destination:=TR.Range("A" & (lastrowtr + 1))
TR.Activate
'delete all blank rows in column 2
TRFRng.AutoFilter field:=3, Criteria1:="="
TRFRng.SpecialCells _
(xlCellTypeVisible).EntireRow.Delete
'subtotal formulas
Set paidOUTrng = TR.Range("d9:d" & lastrowtr)
Set paidINrng = TR.Range("E9:E" & lastrowtr)
paidOUTrng.Name = "PaidOUT"
paidINrng.Name = "PaidIN"
TR.Range("D3").Formula = "=subtotal(9,(PaidOUT)"
TR.Range("E3").Formula = "=subtotal(9,(PaidIN))"
TR.AutoFilterMode = False
'apply autofilter
TRFRng.AutoFilter
SI.Visible = False
Application.ScreenUpdating = True
</code>[COLOR=#333333]End Sub[/COLOR][COLOR=#333333]
I've already been advised that i haven't put in Dim SI as Worksheet, and after "set SI = sheets("SI") for both sheets respectively, however when i added these it comes up with another error saying "duplicate declaration in current scope"
If anyone can help it would be much appreciated. This needs to work on excel 2010, but I created the sheet on excel 2013 (I use 2010 at work but 2013 at home. due to my job I can't take my stuff home)
data:image/s3,"s3://crabby-images/a0dd6/a0dd67a17ec8b6e6bcb45d7047f3d9bfe87084bb" alt="Smile :) :)"