python天天进步(8)--网络编程之文件下载
2009-03-23 15:59
751 查看
真是越看越喜欢python啊,想要了解它提供的http和ftp下载功能,原来是如此的简单。
1、相应模块
ftplib模块定义了FTP类和一些方法,用以进行客户端的ftp编程。我们可用python编写一个自已的ftp客户端程序,用于下载文件或镜像站点。如果想了解ftp协议的详细内容,请参考RFC959或是查看python帮助吧。
Urllib模块提供了非常高级的接口来从网络上抓取数据,主要使用到的是urlopen函数,跟open函数功能比较相似,这里我们要用到urlretrieve()函数来实现从http服务器上下载文件。
2、实例实现FTP下载和上传
from ftplib import FTP
import sys
def ftpdownload(path,file):
ftp = FTP()
ftp.set_debuglevel(2) #打开调试级别2,显示详细信息
ftp.connect('**IP**') #连接ftp服务器
ftp.login(user,password) #输入用户名和密码
print ftp.getwelcome() #显示ftp服务器的欢迎信息
ftp.cwd(path) #选择操作目录
bufsize = 1024 #设置缓冲区大小
file_handler = open(file,'wb').write #以写模式在本地打开文件
strBuffer = 'RETR ' + file
ftp.retrbinary(strBuffer,file_handler,bufsize) #接收服务器上文件并写入本地文件
ftp.set_debuglevel(0) #关闭调试
ftp.quit() #退出ftp服务器
if __name__ == '__main__':
path1 = 'download/test/'
file1 = 'test1.rar'
if len(sys.argv) == 3:
try:
ftpdownload(sys.argv[1],sys.argv[2]) #命令行输入文件在ftp上的路径和文件名,
except IOError:
print "please input the correct path and filename"
else:
ftpdownload(path1,file1)
上传文件非常类似,对应的上传函数storbinary。
from ftplib import FTP
import sys,os
def ftpdownload(path,file):
ftp = FTP()
ftp.set_debuglevel(2)
ftp.connect('**IP**')
ftp.login(user,password)
print ftp.getwelcome()
ftp.cwd(path)
bufsize = 1024
file_handler = open(file,'rb') #读方式打开上传文件
strBuffer = 'RETR ' + file
ftp.storbinary(strBuffer,file_handler,bufsize) #上传文件
ftp.set_debuglevel(0)
ftp.quit()
if __name__ == '__main__':
path1 = 'download/test/'
file1 = '4.jpg'
if len(sys.argv) == 3:
try:
ftpdownload(sys.argv[1],sys.argv[2])
except IOError:
print "please input the correct path and filename"
else:
ftpdownload(path1,file1)
3、实例实现HTTP下载
http下载真的是超级简单,一个函数就搞定,这里通过传入要下载的地址下载文件,并计算下载时间,我想的感觉是比较笨的计算时间的方法,不知道谁有高招呢?
import urllib
import sys
def download(url):
starttime = datetime.datetime.now()
print 'download start time is %s'% starttime
urllib.urlretrieve(url,'test.exe') #开始下载,test.exe为下载后保存的文件名
endtime = datetime.datetime.now()
print 'download end time is %s'% endtime
print 'you download the file use time %s s' % (endtime - starttime).seconds
if __name__ == '__main__':
if len(sys.argv) == 2:
try:
download(sys.argv[1])
except IOError:
print 'url not found'
else:
download('http://www.python.org/‘')
vivilisa write in 03.20.2009
1、相应模块
ftplib模块定义了FTP类和一些方法,用以进行客户端的ftp编程。我们可用python编写一个自已的ftp客户端程序,用于下载文件或镜像站点。如果想了解ftp协议的详细内容,请参考RFC959或是查看python帮助吧。
Urllib模块提供了非常高级的接口来从网络上抓取数据,主要使用到的是urlopen函数,跟open函数功能比较相似,这里我们要用到urlretrieve()函数来实现从http服务器上下载文件。
2、实例实现FTP下载和上传
from ftplib import FTP
import sys
def ftpdownload(path,file):
ftp = FTP()
ftp.set_debuglevel(2) #打开调试级别2,显示详细信息
ftp.connect('**IP**') #连接ftp服务器
ftp.login(user,password) #输入用户名和密码
print ftp.getwelcome() #显示ftp服务器的欢迎信息
ftp.cwd(path) #选择操作目录
bufsize = 1024 #设置缓冲区大小
file_handler = open(file,'wb').write #以写模式在本地打开文件
strBuffer = 'RETR ' + file
ftp.retrbinary(strBuffer,file_handler,bufsize) #接收服务器上文件并写入本地文件
ftp.set_debuglevel(0) #关闭调试
ftp.quit() #退出ftp服务器
if __name__ == '__main__':
path1 = 'download/test/'
file1 = 'test1.rar'
if len(sys.argv) == 3:
try:
ftpdownload(sys.argv[1],sys.argv[2]) #命令行输入文件在ftp上的路径和文件名,
except IOError:
print "please input the correct path and filename"
else:
ftpdownload(path1,file1)
上传文件非常类似,对应的上传函数storbinary。
from ftplib import FTP
import sys,os
def ftpdownload(path,file):
ftp = FTP()
ftp.set_debuglevel(2)
ftp.connect('**IP**')
ftp.login(user,password)
print ftp.getwelcome()
ftp.cwd(path)
bufsize = 1024
file_handler = open(file,'rb') #读方式打开上传文件
strBuffer = 'RETR ' + file
ftp.storbinary(strBuffer,file_handler,bufsize) #上传文件
ftp.set_debuglevel(0)
ftp.quit()
if __name__ == '__main__':
path1 = 'download/test/'
file1 = '4.jpg'
if len(sys.argv) == 3:
try:
ftpdownload(sys.argv[1],sys.argv[2])
except IOError:
print "please input the correct path and filename"
else:
ftpdownload(path1,file1)
3、实例实现HTTP下载
http下载真的是超级简单,一个函数就搞定,这里通过传入要下载的地址下载文件,并计算下载时间,我想的感觉是比较笨的计算时间的方法,不知道谁有高招呢?
import urllib
import sys
def download(url):
starttime = datetime.datetime.now()
print 'download start time is %s'% starttime
urllib.urlretrieve(url,'test.exe') #开始下载,test.exe为下载后保存的文件名
endtime = datetime.datetime.now()
print 'download end time is %s'% endtime
print 'you download the file use time %s s' % (endtime - starttime).seconds
if __name__ == '__main__':
if len(sys.argv) == 2:
try:
download(sys.argv[1])
except IOError:
print 'url not found'
else:
download('http://www.python.org/‘')
vivilisa write in 03.20.2009
相关文章推荐
- python天天进步(6)--网络编程之数据传输TCP
- python天天进步(5)--网络编程之数据传输UDP
- python网络编程之文件下载实例分析
- python网络编程之文件下载实例分析
- Python:FTP上传和下载文件编程
- python读取串口、网络编程、文本处理与文件操作
- 网络编程之实现文件上传下载
- 网络编程练习 -- 大文件下载
- Python网络编程之基于socket实现文件上传
- 网络编程---(数据请求+slider)将网络上的大文件下载到本地,并打印其进度
- Net网络通讯编程[利用Socket实现字串、文件、序列化对象传输]--前面6篇博文全部源代码下载地址
- Linux网络编程一步一步学-自己编写一个HTTP协议的目录浏览和文件下载服务器
- python----文件、数据库、网络编程
- python天天进步--文件操作之遍历目录
- iOS-网络编程 文件上传和断点离线下载
- Python -- 网络编程 -- Socket发送文件
- python天天进步(3)--文件操作之遍历目录
- 网络编程--多线程断点下载文件
- iOS开发之网络编程--小文件下载
- iOS开发之网络编程--4、NSURLSessionDataTask实现文件下载(离线断点续传下载) <进度值显示优化>