吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1345|回复: 26
收起左侧

[其他原创] Excle检测百度网盘是否失效

  [复制链接]
aichiyu 发表于 2024-5-2 07:46

打开开发者工具 - 点击Visual Basic - 选择表右键点击插入选择模块 - 复制代码进去

vba不支持并发所以很慢,如果很多链接建议打开延迟。

最低延迟1秒 删除开头'

'Application.Wait (Now + TimeValue("0:00:01")) ' 时间单位是秒,所以这里是1秒,如果要500毫秒,可以设置为0.5秒

最后一行可以把 For i = 开始 To 结束 结束替换为 Cells(Rows.Count, linkColumn).End(xlUp).Row

Sub 访问链接并写入结果()
    Dim objHTTP As Object
    Dim strURL As String
    Dim strResult As String
    Dim i As Integer
    Dim linkColumn As Integer
    Dim 开始 As Integer
    Dim 结束 As Integer

    ' 提示用户输入链接所在的列
    linkColumn = InputBox("请输入链接所在的列(例如:B列输入2,结果显示2+1列 C列)", "链接在哪一列", 2)
    开始 = InputBox("请输入第几行开始", "行数", 1)
    结束 = InputBox("请输入第几行结束", "行数", 10)

    ' 从指定的列开始遍历链接,直到最后一行 Cells(Rows.Count, linkColumn).End(xlUp).Row
    For i = 开始 To 结束
        ' 获取当前行的链接地址
        strURL = Cells(i, linkColumn).Hyperlinks(1).Address

        ' 创建 HTTP 请求对象
        Set objHTTP = CreateObject("MSXML2.XMLHTTP")

        ' 发送 HTTP 请求
        objHTTP.Open "GET", strURL, False
        objHTTP.send

        ' 获取请求结果
        strResult = objHTTP.responseText

        ' 判断标题内容并写入相应的单元格
        If InStr(strResult, "<title>百度网盘-链接不存在</title>") > 0 Then
            Cells(i, linkColumn + 1).Value = "失效"
        ElseIf InStr(strResult, "<title>百度网盘 请输入提取码</title>") > 0 Then
            Cells(i, linkColumn + 1).Value = "链接没问题"
        Else
            Cells(i, linkColumn + 1).Value = "未知状态,可能不需要提取码"
        End If

        ' 将结果写入当前行的下一列单元格
        'Cells(i, linkColumn + 2).Value = strResult

        ' 添加延迟500毫秒
        'Application.Wait (Now + TimeValue("0:00:01")) ' 时间单位是秒,所以这里是1秒,如果要500毫秒,可以设置为0.5秒

    Next i
End Sub

免费评分

参与人数 4吾爱币 +9 热心值 +3 收起 理由
苏紫方璇 + 7 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!
MUlanzi + 1 谢谢@Thanks!
执骨哟 + 1 感谢发布原创作品,吾爱破解论坛因你更精彩!
jy138290 + 1 + 1 谢谢@Thanks!

查看全部评分

本帖被以下淘专辑推荐:

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

deson37234 发表于 2024-5-2 15:01
Option Explicit

Function CheckBaiduPanLink(ByVal url As String) As Boolean
    Dim http As Object
    Set http = CreateObject("MSXML2.ServerXMLHTTP")
    http.Open "HEAD", url, False
    http.Send
    CheckBaiduPanLink = (http.Status = 200)
End Function

Sub Test()
    Dim url As String
    url = "https://pan.baidu.com/s/1gfQ7YUW" '请替换为实际的百度网盘链接
    If CheckBaiduPanLink(url) Then
        MsgBox "链接有效"
    Else
        MsgBox "链接失效"
    End If
End Sub
deson37234 发表于 2024-5-3 17:23
aichiyu 发表于 2024-5-2 15:29
你这判单是有问题的。。。

肯定不是最终的结果  表格数据清洗 ,为了得到我最终的需求  调试了差不多两个钟  不过ai真的方便我们这些门外汉  只需要知道原理即可  不用深入学习
士兵许三多 发表于 2024-5-2 07:55
龍謹 发表于 2024-5-2 07:57
学习学习,曾经看了一段时间的VBA教程。
deffedyy 发表于 2024-5-2 08:09
学习学习
泡菜久坛 发表于 2024-5-2 08:54
学习一点VBA,简单用用不错
Finssss 发表于 2024-5-2 09:15
感谢大佬分享,学习了
bjxiaoyao 发表于 2024-5-2 09:23
学习了,正在研究VBA
MQ19781011 发表于 2024-5-2 09:58
越来越简单了。。。
jnath_126 发表于 2024-5-2 09:59
批量检测,不错,可以研究学习下
dazuyishi1314 发表于 2024-5-2 10:09
太牛了吧
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-24 16:13

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

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