解决python 上传图片限制格式问题
终于忙完有空更新了,这次说下一个比较简单的东西,限制上传图片格式问题。
先上代码!
img_file = 'D:\\image\\test.jpg' # uuid生成文件名 key = shortuuid.ShortUUID().random(length=9) if img_file.size > 2097152: raise exceptions.APIException('图片大小超出限制') # file_postfix = img_file.name.split('.')[1] suffix = img_file.name.rfind('.') if suffix == -1: raise exceptions.APIException('图片不正确') file_postfix = img_file.name[suffix + 1:] if file_postfix not in ['jpg', 'png', 'gif', 'bmp', 'jpeg', 'JPG', 'PNG', 'BMP', 'JPEG', ]: raise exceptions.APIException('图片格式不正确') file_name = key + '.' + file_postfix
以前项目里总是再用file_postfix = img_file.name.split('.')[1]
这种方法再取文件后缀进行判断格式,这种方法对普通的文件名还是没问题的例如:图片1.jpg、图片2.jpg、图片3.jpg。但是遇到www.图片1.jpg这种的图片名称就会爆炸,因为图片名称中存在两个.
suffix = img_file.name.rfind('.')
而str的rfind方法就可以避免这种问题,因为这是反响寻找。举个例子
a = '123456' print('下标', a.rfind('5'))
输出结果:下标 4
a = '123456' print('下标', a.rfind('7'))
输出结果: 下标 -1
rfind方法从字符串最后以为开始找,找到返回下标,找不到返回-1。
所以 www.test.jpg 这种格式的图片他会从最后位置开始找.找到之后在截取就只剩jpg了,也就好判断了。
要注意的是rfind的下标是从0开始的,所以截取的时候记得加1。
行了 其他的基本没啥了。这篇文章就到这吧,最近会更新上传图片到微信服务器。
总结
以上所述是小编给大家介绍的解决python 上传图片限制格式问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
相关推荐
-
python 实现上传图片并预览的3种方法(推荐)
在常见的用户注册页面,需要用户在本地选择一张图片作为头像,并同时预览. 常见的思路有两种:一是将图片上传至服务器的临时文件夹中,并返回该图片的url,然后渲染在html页面:另一种思路是,直接在本地内存中预览图片,用户确认提交后再上传至服务器保存. 这两种方法各有利弊,方法一很明显,浪费流量和服务器资源:方法二则加重了浏览器的负担,并且对浏览器的兼容性要求更高(在某些低版本中的IE浏览器不支持). 以下是实现上述思路的方法: 1. 模板文件 test.html <!DOCTYPE html>
-
python使用新浪微博api上传图片到微博示例
复制代码 代码如下: import urllib.parse,os.path,time,sysfrom http.client import HTTPSConnectionfrom PyQt5.QtCore import *from PyQt5.QtGui import *from PyQt5.QtWidgets import * #pathospath=sys.path[0]if len(ospath)!=3: ospath+='\\'ospath=ospath.replace('\\'
-
Python中暂存上传图片的方法
很简单的代码,记录一下. 复制代码 代码如下: import Image image = Image.open('a.jpg') import cStringIO buf = cStringIO.StringIO() image.save(buf, image.format,quality=75) data = buf.getvalue() a = u.writeFile('/this/logo.jpg',data,True) 应用在 使用djan
-
解决python 上传图片限制格式问题
终于忙完有空更新了,这次说下一个比较简单的东西,限制上传图片格式问题. 先上代码! img_file = 'D:\\image\\test.jpg' # uuid生成文件名 key = shortuuid.ShortUUID().random(length=9) if img_file.size > 2097152: raise exceptions.APIException('图片大小超出限制') # file_postfix = img_file.name.split('.')[1] suf
-
解决Python 中英文混输格式对齐的问题
Python中使用str.format进行格式化输出 format使用方法较多,这里只说明其在填充与对齐上的使用方法: 填充与对齐 填充常跟对齐一起使用 ^.<.>分别是居中.左对齐.右对齐,后面带宽度 :号后面带填充的字符,只能是一个字符,不指定的话默认是用空格填充 例如: ulist.append([1,"清华大学","10" ]) ulist.append([2,"中国科学技术大学","10"]) ulist
-
解决python将xml格式文件转换成txt文件的问题(xml.etree方法)
概述 先来介绍一下xml格式的文件,从数据分析的角度去看xml格式的数据集,具有以下的优点开放性(能在任何平台上读取和处理数据,允许通过一些网络协议交换xml数据).简单性(纯文本,能在不同的系统之间交换数据).结构和内容分离(不同于HTML,数据的显示和数据本身是分开的).可扩展性(派生出其他标记语言) 问题描述 那么我们在进行数据分析的时候,如何运用xml里面的数据呢? 我们就需要将这类文件转化成其他类型的文件. (其实我认为说成提取xml的数据组成新的类型文件比较好一点) 就我个人的观点,
-
简单解决Python文件中文编码问题
读写中文 需要读取utf-8编码的中文文件,先利用sublime text软件将它改成无DOM的编码,然后用以下代码: with codecs.open(note_path, 'r+','utf-8') as f: line=f.readline() print line 这样就可以正确地读出文件里面的中文字符了. 同样的,如果要在创建的文件中写入中文,最好也和上面差不多: with codecs.open(st,'a+','utf-8') as book_note: book_note.wri
-
解决Python字典写入文件出行首行有空格的问题
模拟购物车程序,判断用户薪资是否是0 如果是0就需要输入薪资,并记录到文件内. 可以预先存个字典格式的字符串,然后去读取文件的时候读到的是字字符串然后再去用eval去转换成字典. 当我们覆盖写到文件的时候就会发现首行会有空格,当我们再去读取eval的时候就会报错,那怎么样可以解决这个问题呢! import json info = { 'lisi':0, 'zhangshan':100, } f = open('json.txt','w') f.write(json.dumps(info)) {"
-
解决python使用open打开文件中文乱码的问题
代码如下: 先在D盘下新建一个html文档,然后在里面输入含有中文的Html字符如下图,然后我们首先使用中文格式对读取的字符进行解码再用utf-8的模式对字符进行进行编码,然后就能正确输出中文字符 # -*- coding: UTF-8 -*- file1 = open("D:/1.html", mode='rb+') data = file1.read().decode('gbk').encode('utf-8') print data 以上这篇解决python使用open打开文件中
-
解决python大批量读写.doc文件的问题
前言: java语言读写.doc的出现乱码问题: 大家都知道当我们利用java语言读写.doc文件时,无论是利用流的方式将.doc文件的内容输出到控制台(console),还是将其写到其他文件中,无论你采取何种编码格式(utf-8,gbk等)输出,你看到的内容99%都是乱码. java语言读写.doc的出现乱码问题原因分析: .doc文件是微软开发的用于办公的编辑文字的软件之一,如果说一篇word文档的字体格式采用的是utf-8,那么你采用utf-8格式读写该文档,应该能够正确输出汉字,但是一旦
-
解决Python网页爬虫之中文乱码问题
Python是个好工具,但是也有其固有的一些缺点.最近在学习网页爬虫时就遇到了这样一种问题,中文网站爬取下来的内容往往中文显示乱码.看过我之前博客的同学可能知道,之前爬取的一个学校网页就出现了这个问题,但是当时并没有解决,这着实成了我一个心病.这不,刚刚一解决就将这个方法公布与众,大家一同分享. 首先,我说一下Python中文乱码的原因,Python中文乱码是由于Python在解析网页时默认用Unicode去解析,而大多数网站是utf-8格式的,并且解析出来之后,python竟然再以Unicod
-
解决python 读取excel时 日期变成数字并加.0的问题
excel 文件内容如下: 读取excel内容: import xlrd from datetime import datetime from xlrd import xldate_as_datetime, xldate_as_tuple filename = r'C:\Users\Administrator\Desktop\niceloo\10月\流水.xlsx' rbook = xlrd.open_workbook(filename) table = rbook.sheets()[0] ro
-
解决python xlrd无法读取excel文件的问题
读取文件时报错: xlrd.biffh.XLRDError: Unsupported format, or corrupt file: Expected BOF record; found '<?xml' 该xls文件在打开时确实会警告该文件与扩展名格式不一致.用文本编辑器打开该xls文件查看,发现确实不是xls文件,而是xml文件被保存为了xls文件. 解决办法:将文件后缀名改为.xml,作为xml文件读入. 改名代码: import os os.rename(u"D:\PycharmP
随机推荐
- 巧用批处理解决IE不支持JavaScript等问题
- 详解angularJS+Ionic移动端图片上传的解决办法
- Spring MVC中自定义拦截器的实例讲解
- 基于Oracle的高性能动态SQL程序开发
- 深入.net调用webservice的总结分析
- 用JavaScript对JSON进行模式匹配(Part 1-设计)
- 一个简单MVC5 + EF6示例分享
- phpmyadmin安装时提示:Warning: require_once(./libraries/common.inc.php)错误解决办法
- php-5.2下php.ini 中文版配置说明第1/3页
- python中异常报错处理方法汇总
- js实现九宫格拼图小游戏
- Android编程实现获得内存剩余大小与总大小的方法
- windows下Nginx日志处理脚本
- SQL Server阻止保存修改表结构的解决方法
- ubuntu关于docker一些事(推荐)
- 用C#写的ADSL拨号程序的代码示例
- 987MB提供1987M免费php空间申请/可绑米
- JavaScript复制内容到剪贴板的两种常用方法
- Spring Cloud中FeignClient实现文件上传功能
- 深入理解docker容器中的uid和gid