0

我有一个 xls/csv 图像列表:

Name        image url
test.jpg    http://test.com/232dd.jpg
test2.jpg   http://test.com/2390j.jpg

我有大约 200 个...有没有办法下载列表并将它们命名为 xls 文件中标识的名称?

这是我的 Excel VBA:

Private Declare Function URLDownloadToFile Lib "urlmon" _
    Alias "URLDownloadToFileA" (ByVal pCaller As Long, _
    ByVal szURL As String, ByVal szFileName As String, _
    ByVal dwReserved As Long, ByVal lpfnCB As Long) As Long

Private Sub download_pics()
  Dim rng As Range
  Dim cell As Variant

  Set rng = Range("A1:B10")
  For Each cell In rng
    ' Download the file.
    URLDownloadToFile 0, cell(rng, 2).Value, "C:\" & cell(rng, 1).Value, 0, 0
  Next
End Sub

使用 URLDownloadToFile 遇到类型不匹配错误

4

1 回答 1

0

OK 类型不匹配与您的迭代有关。您需要指定如何rng使用该For each cell in rng语句进行迭代,例如:

For each cell in rng.Rows

否则,它将该语句视为For each cell in rng.Cells引发不匹配错误。

我对代码进行了一些修改(基于 Sid 在此处的回答),因此它会检查以确保文件下载成功,但大多数情况下您发现的内容是正确的,您只需要稍微不同地实现它。

Private Declare Function URLDownloadToFile Lib "urlmon" _
    Alias "URLDownloadToFileA" (ByVal pCaller As Long, _
    ByVal szURL As String, ByVal szFileName As String, _
    ByVal dwReserved As Long, ByVal lpfnCB As Long) As Long

Private Sub download_pics()
  Dim rng As Range
  Dim myRow As Range
  Dim imgName As String
  Dim fileLocation As String
  Dim Ret As Long 'return value from the URLDownloadToFile function
  Set rng = Range("A1:B10")
  For Each myRow In rng.Rows
    With myRow
        imgName = .Columns(2).Value
        fileLocation = "C:\" & .Columns(1).Value
        With .Columns(1).Offset(, 2)
            If URLDownloadToFile(0, imgName, fileLocation, 0, 0) = 0 Then
                .Value = "downloaded successfully"
            Else:
                .Value = "download failed!"
            End If
        End With
    End With
  Next
End Sub
于 2013-09-16T14:05:17.497 回答