注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

零售创新,创新那些事儿,SPSS,VBA

零售创新

 
 
 

日志

 
 
关于我

新浪微博,零售创新 研究经理,数据分析师 希望和市场研究和零售业的同事共同进步! 本博客发表的都是免费或试用的资料,如果有版权问题请发邮件wangli12a@163.com联系删除。 spss excel vba blog

网易考拉推荐

VBA 复制 网站内容到sheet中  

2012-09-20 14:11:37|  分类: VB和VBA知识 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
Sub 品牌100查询()
'
' 宏1 宏
'
Dim ie
For i = 1 To 100
'MsgBox Sheets(1).Cells(i, 1)

weburl = "http://search.360buy.com/Search?keyword=" & Sheets(1).Cells(i, 1)
  With Worksheets

        Set Sh = .Add(after:=Worksheets(.Count))
      
        Sh.Name = Sheets(1).Cells(i, 1)

      End With

Set ie = CreateObject("internetexplorer.application")
            '网页内容到EXCEL的SHEET表中
            With ie
                 .Visible = True
                 .navigate weburl
                  Do Until .readystate = 4
                     DoEvents
                 Loop
                 .document.body.Focus
                 .document.execcommand "selectall"
                 .document.execcommand "copy"
                 Range("A1").Select
                 ActiveSheet.Paste
               .Quit           ' quit 方法在有的电脑上能运行,在有的电脑上报错误。
           '想用sendkeys关闭网页,就是说直接把浏览器关掉都行,求指点
        '       SendKeys "%{F4}", True     'Alt+F4关闭

                 
             End With
              Set ie = Nothing
 

Next

End Sub


Private Sub 提取数()

    Dim a(100)
    
    Dim Sh As Worksheet
'Sheets("Sheet1").Select

For j = 10 To 25

 weburl = "http://search.360buy.com/Search?keyword=%E5%8D%9A%E5%A3%AB%E8%83%BD&enc=utf-8&area=1"
 
    With Worksheets

        Set Sh = .Add(after:=Worksheets(.Count))
      
        ' Sh.Name = a(j)

      End With
    With ActiveSheet.QueryTables.Add(Connection:=weburl, Destination:=Cells(j + 1, 1))
               'post字串
        .BackgroundQuery = True
        .WebSelectionType = xlSpecifiedTables
         .WebTables = 3    '导入网页中的第一个表,也只有一个表格,网页上可能会包含很多个表格,表格让你组织网页内容。当在记事本里查看HTML源代码时,你会发现通过下述标签你很容易识别这些表格:<TABLE>(表格开始)和</TABLE>(表格结束)
        .WebFormatting = xlWebFormattingAll
        .RefreshStyle = xlOverwriteCells
        .AdjustColumnWidth = True
        On Error GoTo Wlcw
        .Refresh BackgroundQuery:=False      '发送命令?
        On Error GoTo 0
        .SaveData = True
    End With

Next
Wlcw:     '网络不通
    If P_cxzlly = "sccx" Or P_cxzlly = "qmcx" Then
        aa = MsgBox("网络不通,请手动打开网络http://10.228.98.9/试试!", vbOKOnly, "提示")
    End If
    Exit Sub
End Sub

Function del()
   On Error Resume Next
    Dim oRecrodset
    Dim arr
    Dim sConStr As String
    Dim sSql As String
    Dim oWk As Worksheet
    Dim i As Integer
    Dim j As Integer
    Dim sFN, Sname As String
    Application.DisplayAlerts = False
Sname = ActiveSheet.Name
    For Each oWk In Application.Worksheets
        If oWk.Name <> Sname Then
            oWk.Delete
        End If
    Next
    Application.DisplayAlerts = True

End Function

  评论这张
 
阅读(1068)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017