ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助]如何利用VBA实现将文件上载到主机上(FTP),谢谢!

[复制链接]

TA的精华主题

TA的得分主题

发表于 2002-6-26 10:42 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
请问利用VBA可否实现文件上载功能,如果能的话,如何来实现。我是VBA的初学者,实在不知如何下手,请各位指点为盼!谢谢!

TA的精华主题

TA的得分主题

发表于 2002-6-26 21:53 | 显示全部楼层
我也想知道。不仅是上载,下载如何写代码,也请指点一二。

TA的精华主题

TA的得分主题

发表于 2002-6-26 23:45 | 显示全部楼层
使用 Internet Transfer 控件(工具>>附加控件:Microsoft Internet Transfer Control) 以下为帮助文件, 我没试过: Internet Transfer 控件实现了两种广泛使用的 Internet 协议: 超文本传送协议(HyperText Transfer Protocol)(HTTP) 和文件传送协议(File Transfer Protocol) (FTP)。使用 Internet Transfer 控件可以通过 OpenURL 或 Execute 方法连接到任何使用这两个协议的站点并检索文件。 可能的用途 在应用程序中添加 FTP 浏览器。 创建自动从公共 FTP 站点下载文件的应用程序。 分析 World Wide Web 站点中的图形引用,并只下载图形。 提供以自定义格式显示从 Web 页获得的动态数据。 基本操作 Internet Transfer 控件的功能依赖于将要使用的协议。由于所支持的两种协议工作起来不尽相同,所能够进行的操作就依赖于正在使用的协议。例如,GetHeader 方法只能用于 HTTP(HTML 文档)协议。 然而,有些过程对两个协议是通用的。最基本的,如果要使用任何一个协议,则必须: 将 AccessType 属性设置为合法的代理服务器。 用合法的 URL 调用 OpenURL 方法。 用合法的 URL 和协议支持的命令调用 Execute 方法。 用 GetChunk 方法从缓冲区获取数据。 设置 AccessType 属性:使用代理服务器 为了与 Internet 建立任何形式的连接,必须确定计算机如何连接到 Internet 上。如果在 intranet 上,可能需要提供代理服务器才能连接到 Internet 上。 简单地说,代理服务器是计算机和 Internet 之间的媒介。intranet 上所有需要连接到 Internet 上的计算机,都必须通过代理服务器。代理行使 intranet 和 Internet 之间的防火墙功能,能够阻止非法的最终用户和外部请求,也就保护了 intranet 不受破坏。 要查找计算机中的代理设置值,请按照以下步骤执行: 注意 下面的步骤只能用于 Windows 95 和 Windows NT(R) 4.0 系统。 在计算机的“任务栏”中,单击“启动”。 在“设置”项中,单击“控制面板”。 双击“Internet”图标。 在“Internet 属性”对话框中,单击“连接”。 在“代理服务器”中,确认选中了“通过代理服务器连接”复选框。 如果选中了,则单击“设置”。在该对话框中可以找到能够用于多种协议的代理服务器的名称。如果没有定义代理服务器,请与系统管理员联系,以获得可用的代理服务器。 如果希望使用对话框中未列出的代理服务器,可将 AccessType 属性设置为 icNamedProxy (2)。然后将 Proxy 属性设置为代理服务器的名称,如下面的代码所示: Inet1.Proxy = "myProxyName" Inet1.AccessType = icNamedProxy 另一方面,如果希望使用缺省代理服务器(由计算机的注册表决定),则可以忽略 Proxy 属性,而只需将 AccessType 设置为 icUseDefault (0)。 AccessType 的设置值在下表中列出: 常数 值 描述 icUseDefault 0 (缺省)用作缺省。控件使用注册表中的缺省设置访问 Internet。 icDirect 1 直接连接 Internet。该控件可直接连接到 Internet。 icNamedProxy 2 命名的代理服务器。指示该控件使用 Proxy 属性确定的代理服务器。 调用 OpenURL 方法 设置完 AccessType 属性后,最基本的操作就是用合法的 URL 调用 OpenURL 方法。使用 OpenURL 方法时,操作所得到的结果将依赖于目标 URL。例如下面的 URL 将返回在 www.microsoft.com 中找到的 HTML 文档: '名为“Text1”的 TextBox 控件保存了 '该方法的结果。Internet 传输 '控件的名称是“Inet1”。 Text1.Text = Inet1.OpenURL("http://www.microsoft.com") 作为结果,TextBox 控件保存了 HTML 源码,它看上去应和下图显示的相似: 在这种情况下,缺省操作返回的是 URL 定位的 HTML 文档。然而,如果 URL 被改为指向文本文件,则将获得实际的文件。例如,下面的代码: Text1.Text = Inet1. _ OpenURL("ftp://ftp.microsoft.com/disclaimer.txt") 将获得文件的实际文本,如下所示: 提示 在使用 OpenURL 或 Execute 方法时,不需要设置 Protocol 属性。Internet Transfer 控件会自动按 URL 的协议部分确定的协议来设置。 最后,可以用包含附加数据的 URL 调用 OpenURL 方法。例如,很多 Web 站点提供了搜索数据库的能力。要搜索数据库,则需要在发送的 URL 中包含搜索条件。例如下面的代码用条件“find=Maui”调用名为“search.exe”的搜索引擎。 Dim strURL As String strURL = _ "http://www.howzit.com/cgi-bin/search.e xe?find=maui Text1.Text = Inet1.OpenURL(strURL) 如果搜索引擎找到了符合条件的内容,将合成一个 HTML 文档并携带适当的信息返回。 用 OpenURL 方法保存到文件 如果需要将通过 OpenURL 方法获取的数据保存到文件,可以使用 Open、Put 和 Close 语句,如下面的代码所示。该示例先将获得的二进制文件传入 Byte 数组,然后将该数据保存到磁盘中: Dim strURL As String Dim bData() As Byte '数据变量 Dim intFile As Integer '可用文件变量 strURL = _ "ftp://ftp.microsoft.com/Softlib/Softlib.e xe" intFile = FreeFile() '将 intFile 设置为未使用的文件 ' OpenURL 方法的结果首先传入 Byte 数组, '然后将 Byte 数组保存到磁盘。 bData() = Inet1.OpenURL(strURL, icByteArray) Open "C:\Temp\Softlib.e xe" For Binary Access Write _ As #intFile Put #intFile, , bData() Close #intFile 可用类似的过程将文本文件写入磁盘中,不同的只是不再需要 Byte 数组了,数据可以直接保存到文件中: Dim strURL As String 'URL 字符串 Dim intFile As Integer '可用文件变量 IntFile = FreeFile() strURL = "http://www.microsoft.com" Open "c:\temp\MSsource.txt" For Output _ As #IntFile Write #IntFile, Inet1.OpenURL(strURL) Close #IntFile 同步和异步传输 OpenURL 方法以同步方式传输数据。在这里,同步指的是传输操作未完成之前,不能执行其它过程。这样数据传输就必须在执行其它代码之前完成。 而 Execute 方法以异步方式传输数据。在调用 Execute 方法时,传输操作与其它过程无关。这样,在调用 Execute 方法后,在后台接收数据的同时,即可同时执行其它代码。 对 Internet Transfer 控件的使用者来说这意味着什么?简单地说,用 OpenURL 方法能够直接得到可保存到磁盘的数据流(如上所述),或者直接在 TextBox 控件中阅览(如果数据是文本格式的)。从另一方面说,如果用 Execute 方法获取数据,则必须用 StateChanged 事件监视该控件的连接状态。当达到适当的状态时,调用 GetChunk 方法从控件的缓冲区获取数据。下面更详细地讨论这一操作。 在 FPT 协议中使用 Execute 方法 Execute 方法具有四个参数:url、operation、data 和 requestHeaders。FTP 操作只用到了 operation 参数和 url 参数,其中后者是可选的。例如,要从远程计算机中得到一个文件,可用下面的代码: Inet1.Execute "FTP://ftp.microsoft.com", _ "GET disclaimer.txt C:\Temp\Disclaimer.txt" 如果正在用 FTP 从匿名 FTP 服务器中获取文件,就应熟悉在服务器目录树中漫游的特定命令,以及将其中文件获取到本地的硬盘中的命令。例如,要用 FPT 协议改变目录,应使用带有希望改变到的目录路径的“CD”命令。 对绝大多数通用操作,如将文件传入服务器,以及从服务器获取文件,Internet 传输控件在 Execute 方法中使用了(与 FTP)相同或相近的命令。例如,下面的代码将“CD”命令作为 Execute 方法的参数以改变路径: 'txtURL 文本框包含了要打开的路径。 'txtRemotePath 文本框包含了要改变到的路径。 Inet1.Execute txtURL.Text, "CD " & txtRemotePath.Text 注意 在 Execute 方法中使用 FTP 命令时,没有用到 data 和 requestHeaders 参数。所有的操作和它们的参数都在 operation 参数中作为字符串进行传递;参数之间用空格进行分隔。在下面的描述中,不要把“file1”和“file2”项与 data 和 requestHeaders 参数搞混。 FTP 操作的语法是: operationName file1 file2 例如,要获取文件,在下面的代码中包含了操作的名称 (“获取”),以及该操作所需的两个文件名: '得到名为“Disclaimer.txt”的文件,并将其复制到 ' C:\Temp\Disclaimer.txt。 Inet1.Execute, _ "GET Disclaimer.txt C:\Temp\Disclaimer.txt" 下表列出了该控件支持的 FTP 命令: 操作 描述 示例 CD file1 改变目录。改变到由 file1 指定的目录中。 Execute , "CD docs\mydocs" CDUP 改变到父目录。功能与“CD ..”相同。 Execute , "CDUP" DELETE file1 删除由 file1 指定的文件。 Execute , "DELETE discard.txt" DIR [file1] 在由 file1 指定的目录中查找。如果没有指定 file1 目录,则查找当前工作目录。使用 GetChunk 方法返回数据。 Execute , "DIR /mydocs" GET file1 file2 获取由 file1 指定的远程文件,并创建由 file2 指定的新的本地文件。 Execute , _ "GET getme.txt C:\gotme.txt" MKDIR file1 创建由 file1 指定的目录。是否能够成功地执行,取决于用户在远程主机上的权限。 Execute , "MKDIR /myDir" PUT file1 file2 将由 file1 指定的本地文件,复制到由 file2 指定的远程主机文件中。 Execute , _ "PUT C:\putme.txt /putme.txt" PWD 打印工作目录。返回当前目录的名称。用 GetChunk 方法返回数据。 Execute , "PWD" QUIT 结束当前连接。 Execute , "QUIT" RECV file1 file2 与 GET 相同。 Execute , _ "RECV getme.txt C:\gotme.txt" RENAME file1 file2 文件重命名。是否能够成功地执行,取决于用户在远程主机上的权限。 Execute , "RENAME old.txt new.txt" RMDIR file1 删除目录。是否能够成功地执行,取决于用户在远程主机上的权限。 Execute , "RMDIR oldDir" SEND file1 将文件复制到 FTP 站点。(与 PUT 相同) Execute , _ "SEND C:\putme.txt /putme.txt" SIZE file1 返回由 file1 指定文件的大小。 Execute "SIZE /largefile.txt" 重点 如果代理服务器是 CERN 代理服务器,就不允许使用直接的 FTP 连接(使用 Execute 方法)。在这种情况下,要获得文件,则需使用带 Open、Put 和 Close 语句的 OpenURL 方法,就象前面“用 OpenURL 方法保存到文件”提到的那样。还可以用 OpenURL 方法得到目录列表,即将目标目录作为 URL,并调用该方法。 在 HTTP 协议上使用 Execute 方法 HTTP 协议允许客户机用 GET、HEAD、POST 和 PUT 命令向服务器请求数据。下表中列出了这些操作: 操作 描述 示例 GET 获取 url 中命名的文件。 Execute "http://www.microsoft.com" & _ "/default.htm", "GET" HEAD 只获取 URL 属性中命名的文件的文件标头。 Execute , "HEAD" POST 提供附加数据,以支持向远程主机的请求。 Execute , "POST", strFormData PUT 替换指定的 URL 中的数据。 Execute , "PUT", "replace.htm" 通用网关接口和 Execute 方法 很多 World Wide Web 站点提供了搜索数据库的能力。它是通过 HTTP 协议用通用网关接口 (CGI) 发送查询的能力完成的。 在这里不再讨论 CGI 了。然而,如果对 CGI 比较了解,就可用 Execute 方法构造一个应用程序模拟 World Wide Web 站点的行为。例如,下面的代码给出了典型的 CGI 查询字符串: http://www.yippee.com/cgi-bin/find.e xe?find=Hangzhou 如下所示,用 Execute 方法也可以发送同样的查询: Dim strURL As String, strFormData As String strURL = "//www.yippee.com/cgi-bin/find.e xe" strFormData = "find=Hangzhou" Inet1.E xecute strURL, "POST", strFormData 如果希望得到从服务器发回的结果(如上面的示例所示),就必须使用 GetChunk 方法以获取作为结果的 HTML 文档。 在 State 事件中使用 GetChunk 方法 在从远程计算机下载数据时,将建立异步连接。例如,在 Execute 方法中使用“获取”操作,将使服务器获取请求的文件。当获取了整个文件之后,State 参数将返回 icResponseCompleted (12)。在这时候,就可以用 GetChunk 方法从缓冲区中获取数据了。下面的示例中给出了这种情况: Private Sub Inet1_StateChanged(ByVal State As Integer) Dim vtData As Variant '数据变量。 Select Case State '...没有给出其它情况。 Case icResponseCompleted '12 '打开文件用于写入。 Open txtOperation For Binary Access _ Write As #intFile '得到第一个大块。注意:指定 Byte 数组 ' (icByteArray) 以获取二进制文件。 vtData = Inet1.GetChunk(1024, icString) Do While LenB(vtData) > 0 Put #intFile, , vtData '得到下一大块。 vtData = Inet1.GetChunk(1024, icString) Loop Put #intFile, , vtData Close #intFile End Select End Sub 登录到 FTP 服务器 FTP 服务器有两种:公用的和私用的。公用服务器,顾名思义,是对所有人开放的。而私用服务器,除了该服务器的真正用户,其他人不能登录。在这两种情况下,FTP 协议都要求提供用户名和密码。这两个参数用来验明用户,并允许(或禁止)进一步的操作。 要登录到公用服务器,通常的做法是以“匿名”登录 (UserName = "anonymous"),然后发送用户的电子邮件名称作为密码。然而使用 Internet 传输控件这一过程还能够进一步简化。按照缺省规定,如果没有提供 UserName 和 Password 属性值,该控件发送“匿名”作为 UserName,用户的电子邮件名称作为 Password。 如果要登录到私用服务器,只需适当地设置 UserName、Password 和 URL 属性,并调用 Execute 方法,如下面的示例所示: With Inet1 .URL = "ftp://ftp.someFTPSite.com" .UserName = "John Smith" .Password = "mAuI&9$6" .Execute ,"DIR" '返回该目录。 .Execute ,"CLOSE" '关闭连接。 End With 在调用 Execute 方法之后,FTP 连接仍旧打开着。这时可以继续使用 Execute 方法完成其它 FTP 操作,比如 CD 和 GET。如果会话已经完成,使用 Execute 方法执行 CLOSE 操作以关闭连接。也可以通过改变 URL 属性,并调用 OpenURL 或 Execute 方法,自动关闭该连接,这样的操作会关闭当前 FTP 连接,并打开新的 URL。

TA的精华主题

TA的得分主题

发表于 2007-10-17 23:16 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2009-6-13 15:01 | 显示全部楼层
好回覆。
能整個附件就好了,看起來太累

TA的精华主题

TA的得分主题

发表于 2014-8-23 20:32 | 显示全部楼层
向顾问学习,研究下,谢谢!

TA的精华主题

TA的得分主题

发表于 2014-8-23 20:56 | 显示全部楼层
这么老的帖子都出来了。。。。。。。。。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-23 15:46 , Processed in 0.034551 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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