ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 1774|回复: 10

[已解决] 请教各位大神VBA这段代码是什么意思,实在看不懂

[复制链接]

TA的精华主题

TA的得分主题

发表于 2022-10-9 09:25 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
本帖最后由 思维百宝箱 于 2022-10-9 21:33 编辑

能不能就每个内容说明一下,拜托了!

    With IE
        .Visible = True
        .Navigate "http://******"                                                    '输入的网址
        Do Until .ReadyState = 4
            DoEvents
        Loop

        Set tb = .Document.getElementById("table_live")

        r = 4

        For i = 1 To tb.Rows.Length - 1

            If tb.Rows(i).Cells.Length > 9 Then

                 r = r + 1

                 Sheets("sheet1").Range("A" & r) = Split(Split(Split(tb.Rows(i).Cells(0).innerHTML, "chk_")(1), Chr(34))(0), " ")(0) & ""

                Sheets("sheet1").Range("B" & r) = tb.Rows(i).Cells(1).innerText

                 Sheets("sheet1").Range("C" & r) = tb.Rows(i).Cells(2).innerHTML

TA的精华主题

TA的得分主题

发表于 2022-10-9 10:27 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
就是导入网页表格数据,一行有 9 个以上单元格就导入
推荐直接复制法
参考:https://club.excelhome.net/thread-1628424-1-1.html

TA的精华主题

TA的得分主题

发表于 2022-10-9 10:32 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
网抓是涉及知识面很多的任务,不建议初学者去研究这个,学习尽量要循序渐进。

TA的精华主题

TA的得分主题

 楼主| 发表于 2022-10-9 11:34 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
perfect131 发表于 2022-10-9 10:27
就是导入网页表格数据,一行有 9 个以上单元格就导入
推荐直接复制法
参考:https://club.excelhome.net/ ...

大神,这个代码能解释一下吗? Sheets("sheet1").Range("A" & r) = Split(Split(Split(tb.Rows(i).Cells(0).innerHTML, "chk_")(1), Chr(34))(0), " ")(0) & ""

TA的精华主题

TA的得分主题

发表于 2022-10-9 11:58 | 显示全部楼层
本帖最后由 perfect131 于 2022-10-9 12:03 编辑
思维百宝箱 发表于 2022-10-9 11:34
大神,这个代码能解释一下吗? Sheets("sheet1").Range("A" & r) = Split(Split(Split(tb.Rows(i).Cells( ...

我猜截取的应该是数字,看最后加了 &"",转string
split是截取函数,截取网页表格 第 i 行文本,chk_ 至  Chr(34)(双引号)之间的数据,再次从这里面截取空格前面的数据
就好比 aa=Split(Split(Split("chk_99 3333""", "chk_")(1), Chr(34))(0), " ")(0)&""
chk_ 至  Chr(34)(双引号)之间的数据就是 99 3333 ,从这个里面截取 空格 前面的数据

那 aa 就是 99
(1)表示往后,(0)表示往前
最后把截取结果 赋值给 sheet1 工作表 a列 r 行

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2022-10-9 13:18 | 显示全部楼层
perfect131 发表于 2022-10-9 11:58
我猜截取的应该是数字,看最后加了 &"",转string
split是截取函数,截取网页表格 第 i 行文本,chk_ 至 ...

收到,谢谢你,我有空研究一下

TA的精华主题

TA的得分主题

 楼主| 发表于 2022-10-9 13:20 | 显示全部楼层
蓝桥玄霜 发表于 2022-10-9 10:32
网抓是涉及知识面很多的任务,不建议初学者去研究这个,学习尽量要循序渐进。

谢谢版主温馨提醒,学习网抓我怕有点力不从心,修改一下戴拿变成适合自己的还是能实现的请原谅我的好高骛远,投机取巧

TA的精华主题

TA的得分主题

 楼主| 发表于 2022-10-9 13:26 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
perfect131 发表于 2022-10-9 11:58
我猜截取的应该是数字,看最后加了 &"",转string
split是截取函数,截取网页表格 第 i 行文本,chk_ 至 ...

那你还能帮我解释一下这几句代码的意思吗?实在抱歉,还需要麻烦你一下。
Do Until .ReadyState = 4
            DoEvents
        Loop

        Set tb = .Document.getElementById("table_live")

        r = 4

        For i = 1 To tb.Rows.Length - 1

TA的精华主题

TA的得分主题

发表于 2022-10-9 14:27 | 显示全部楼层
''加载网页
Do Until .ReadyState = 4
            DoEvents
        Loop
'''把 ID 为 table_live 的表格赋值给 tb
Set tb = .Document.getElementById("table_live")
''' 从 1 开始 循环 至  tb 表最大行减一
For i = 1 To tb.Rows.Length - 1

基本上,这个看完你也学会网抓了
https://www.bilibili.com/video/BV1uJ411t7hY/

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2023-5-31 08:56 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
perfect131 发表于 2022-10-9 14:27
''加载网页
Do Until .ReadyState = 4
            DoEvents

学习中,谢谢指导。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-10-6 00:36 , Processed in 0.034206 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表