python判断jpeg图片的完整性

用扩展名判断文件格式非常简单,但是有可能是错误的。 jpeg文件有固定的文件头,其文件头的格式如下:

Start Marker  | JFIF Marker | Header Length | Identifier
 
0xff, 0xd8    | 0xff, 0xe0  |    2-bytes    | "JFIF\0"

所以可以通过文件头的方式快速判断文件格式:

def is_jpg(filename):
    data = open(filename,'rb').read(11)
    if data[:4] != '\xff\xd8\xff\xe0' and data[:4]!='\xff\xd8\xff\xe1': 
        return False
    if data[6:] != 'JFIF\0' and data[6:] != 'Exif\0': 
        return False
    return True

也可以通过PIL类库来做判断:

from PIL import Image
def is_jpg(filename):
    try:
        i=Image.open(filename)
        return i.format =='JPEG'
    except IOError:
        return Fals
应用场景 :判断image文件夹中的jpeg文件是否完整,代码如下:

#coding=utf-8
#summary: 判断图片的有效性
import io
import os

from PIL import Image
#判断文件是否为有效(完整)的图片
#输入参数为文件路径
#会出现漏检的情况
def IsValidImage(pathfile):
  bValid = True
  try:
    Image.open(pathfile).verify()
  except:
    bValid = False
  return bValid


def is_valid_jpg(jpg_file):  
    """判断JPG文件下载是否完整 
    """  
    if jpg_file.split('.')[-1].lower() == 'jpg':  
        with open(jpg_file, 'rb') as f:  
            f.seek(-2, 2)  
            return f.read() == '\xff\xd9' #判定jpg是否包含结束字段  
    else:  
        return True

#利用PIL库进行jpeg格式判定,但有些没有结束字段的文件检测不出来
def is_jpg(filename):
    try:
        i=Image.open(filename)
        return i.format =='JPEG'
    except IOError:
        return False
 
allfiles=os.listdir('image')
log_file=open('img_lossinfo.txt','w')
log = open('img_r.txt','w')
log_w=open('img_w.txt','w')
log1=open('img_jpeg.txt','w')
log2=open('img_notjpg.txt','w')
for i in allfiles:
#if 1:
	if i[-4:]=='.jpg':
		f=os.path.join('image',i)
		value=IsValidImage(f)
		if not value:
			log_file.write(i+'\n')
		if is_valid_jpg(f):
			print f
			log.write(i+'\n')
		else:
			log_w.write(i+'\n')
		if is_jpg(f):
			log1.write(i+'\n')
		else:
			log2.write(i+'\n')



### Python 输出图片文件名的方法 在 Python 中,可以利用 `os` 和 `re` 模块来实现输出指定目录下的图片文件名的功能。以下是具体方法: 通过 `os.listdir()` 函数获取目标路径下的所有文件名,并结合正则表达式筛选出符合条件的图片文件名。 #### 使用代码示例 以下是一个完整的代码示例用于输出指定目录下的图片文件名: ```python import os import re def get_image_files(directory): """ 获取指定目录下的所有图片文件名。 参数: directory (str): 要扫描的目标目录 返回: list: 符合条件的图片文件名列表 """ image_extensions = ['jpg', 'jpeg', 'png', 'gif', 'bmp'] # 定义支持的图片扩展名 files_in_directory = os.listdir(directory) # 列举目录中的所有文件和子目录 image_files = [] for file_name in files_in_directory: if os.path.isfile(os.path.join(directory, file_name)): # 确保是文件而非子目录 extension = file_name.split('.')[-1].lower() # 提取文件扩展名并转为小写 if extension in image_extensions: # 如果扩展名匹配,则加入结果列表 image_files.append(file_name) return image_files # 测试函数 directory_path = r'F:\Temp\ZZ' image_list = get_image_files(directory_path) for img_file in image_list: print(img_file) ``` 此代码实现了从给定路径中提取所有具有常见图片扩展名(如 `.jpg`, `.jpeg`, `.png`, `.gif`, `.bmp`)的文件名[^1]。 --- #### 关键点解析 - **列出目录内容** 使用 `os.listdir(path)` 可以返回指定路径下的所有文件和子目录名称[^2]。 - **过滤图片文件** 需要判断文件是否为图片文件,可以通过检查其扩展名完成这一操作。这里定义了一个常见的图片扩展名单供参考[^3]。 - **处理特殊情况** 当前代码仅保留实际存在的文件(排除子目录),并通过字符串分割的方式提取扩展名进行验证。如果存在特殊需求(例如忽略大小写敏感性或支持更多类型的图像格式),可以根据实际情况调整逻辑。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值