python实现文件上传功能_用python 实现上传文件功能 | 学步园

环境 Apache + mod_python

如文件小可以采用这个方式

import os

def form():

return """\

File:

"""

def upload(req):

try: # Windows needs stdio set for binary mode.

import msvcrt

msvcrt.setmode (0, os.O_BINARY) # stdin  = 0

msvcrt.setmode (1, os.O_BINARY) # stdout = 1

except ImportError:

pass

# A nested FieldStorage instance holds the file

fileitem = req.form['file']

# Test if the file was uploaded

if fileitem.filename:

# strip leading path from file name to avoid directory traversal attacks

fname = os.path.basename(fileitem.filename)

# build absolute path to files directory

dir_path = os.path.join(os.path.dirname(req.filename), 'files')

open(os.path.join(dir_path, fname), 'wb').write(fileitem.file.read())

message = 'The file "%s" was uploaded successfully' % fname

else:

message = 'No file was uploaded'

return """\

%s

Upload another file

""" % message

如文件大时,可以分块上传,现在是改良方式

import os

def form():

return """\

File:

"""

# Generator to buffer file chunks

def fbuffer(f, chunk_size=10000):

while True:

chunk = f.read(chunk_size)

if not chunk: break

yield chunk

def upload(req):

try: # Windows needs stdio set for binary mode.

import msvcrt

msvcrt.setmode (0, os.O_BINARY) # stdin  = 0

msvcrt.setmode (1, os.O_BINARY) # stdout = 1

except ImportError:

pass

# A nested FieldStorage instance holds the file

fileitem = req.form['file']

# Test if the file was uploaded

if fileitem.filename:

# strip leading path from file name to avoid directory traversal attacks

fname = os.path.basename(fileitem.filename)

# build absolute path to files directory

dir_path = os.path.join(os.path.dirname(req.filename), 'files')

f = open(os.path.join(dir_path, fname), 'wb', 10000)

# Read the file in chunks

for chunk in fbuffer(fileitem.file):

f.write(chunk)

f.close()

message = 'The file "%s" was uploaded successfully' % fname

else:

message = 'No file was uploaded'

return """\

%s

Upload another file

""" % message

from:http://long.objectis.net/wanglaoriji/yongpython-shixianshangzhuanwenjiangongneng

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值