②. GPT错误:图片尺寸写入excel权限错误

꧂问题最初 ꧁

input输入图片路径
print图片尺寸 大小 长宽高 有颜色占比>0.001的

按照大小排序



将打印信息存储excel表格

文件名 表格路径 图片大小 尺寸 颜色类型 占比信息

input输入的是文件就处理文件
是文件夹📁就处理文件。路径下的图片
1. 是处理本路径图片
2. 处理文件夹下,是遍历此目录树下所有的图片文件

/storage/emulated/0/代码文件/excel/

命名:图片尺寸表格 ("%Y-%m-%d %H:%M:%S").后缀名


꧂ 最初错误❌代码꧁

import os
import glob
import openpyxl
from openpyxl.utils import get_column_letter
from openpyxl.styles import Font
from PIL import Image
from datetime import datetime


def process_image(image_path):
    img = Image.open(image_path)
    image_size = os.path.getsize(image_path)

    width, height = img.size
    color_info = get_color_info(img)

    return {
        '文件名': os.path.basename(image_path),
        '图片大小': format_size(image_size),
        '尺寸': f'{width}x{height}',
        '颜色类型': color_info['types'],
        '占比信息': color_info['proportions']
    }


def get_color_info(img):
    # 获取图片像素信息
    pixels = img.load()

    # 统计颜色的像素数量
    color_counts = {}
    total_pixels = img.width * img.height
    for i in range(img.width):
        for j in range(img.height):
            color = pixels[i, j]
            color_counts[color] = color_counts.get(color, 0) + 1

    # 计算每种颜色的占比
    color_info = {}
    for color, count in color_counts.items():
        proportion = count / total_pixels
        if proportion > 0.001:
            color_info[color] = proportion

    return {
        'types': len(color_info.keys()),
        'proportions': color_info
    }


def format_size(size):
    # 格式化文件大小
    sizes = ['B', 'KB', 'MB', 'GB']
    index = 0
    while size >= 1024 and index < len(sizes) - 1:
        size /= 1024
        index += 1
    return f'{round(size, 2)} {sizes[index]}'


def create_excel_table(data, table_path):
    wb = openpyxl.Workbook()
    ws = wb.active

    # 设置标题行的样式
    title_font = Font(bold=True)
    for col_num, column_title in enumerate(data[0].keys(), 1):
        col_letter = get_column_letter(col_num)
        ws[f'{col_letter}1'] = column_title
        ws[f'{col_letter}1'].font = title_font

    # 填充数据
    for row_num, row_data in enumerate(data, 2):
        for col_num, cell_value in enumerate(row_data.values(), 1):
            col_letter = get_column_letter(col_num)
            ws[f'{col_letter}{row_num}'] = cell_value

    # 自动调整列宽
    for col_num, column_title in enumerate(data[0].keys(), 1):
        col_letter = get_column_letter(col_num)
        ws.column_dimensions[col_letter].auto_size = True

    # 保存表格
    wb.save(table_path)


def process_images(input_path):
    if os.path.isfile(input_path):
        image_files = [input_path]
    elif os.path.isdir(input_path):
        pattern = os.path.join(input_path, '**', '*.jpg')
        image_files = glob.glob(pattern, recursive=True)
    else:
        print("输入路径无效!")
        return

    image_data = []
    for image_file in image_files:
        try:
            image_info = process_image(image_file)
            image_data.append(image_info)
        except Exception as e:
            print(f"处理图片 {image_file} 时出错:{str(e)}")

    timestamp = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
    table_name = f"图片尺寸表格 ({timestamp}).xlsx"
    table_path = os.path.join('/storage/emulated/0/代码文件/excel/', table_name)

    create_excel_table(image_data, table_path)
    print("已创建图片尺寸表格:", table_path)


if __name__ == '__main__':
    input_path = input("请输入文件路径或文件夹路径:")
    process_images(input_path)
    
    
#添加检测:
# 新添加的代码
var = "hello"
print("type:", type(var))
print("value:", str(var))
input("pause at line: {}".format(str(__fil e__.split("/")[-1])+": "+str(30)))
print("help:", help(type(var)))

比,图片尺寸1.2保存表格1.1.py" && exit   <   File "/storage/emulated/0/qpython/评论截 图问题1.矩阵2.1.2.1空行问题3.4.6色心6.6꧂py thon图片:获得颜色占比,图片尺寸1.2保存表格1.1.py", line 123
    input("pause at line: {}".format(str(_ _fil e__.split("/")[-1])+": "+str(30)))
                                         ^ ^^^^^^^^^^^^^^^^^^^^^^^
SyntaxError: invalid syntax. Perhaps you f orgot a comma?
1|:/ $

꧂ 中间的几次错误①꧁

错误发生在第123行的代码中:

input(“pause at line: {}”.format(str(fil e.split("/")[-1])+": "+str(30)))

这行代码中,__file__是一个内置变量,表示当前脚本的文件路径。然后使用split("/")[-1]来获取文件名,并与字符串"pause at line: "和行数30进行拼接。但是,在文件名获取之后,您在__file__split("/")[-1]之间放置了一个空格,导致了语法错误。

解决方法是将空格去掉,并确保代码的各个部分正确连接起来,如下所示:

input(“pause at line: {}”.format(str(file.split("/")[-1]) + ": " + str(30)))

请注意,上述代码只是用于调试目的,如果不需要暂停程序运行,可以将其注释掉或删除。

꧂ 中间的几次错误②꧁

根据错误信息,出现了一个值转换错误。在这段代码中,尝试将一个字典作为Excel表格单元格的值进行赋值,但是Excel表格只能接受基本数据类型的值。

要解决这个问题,你需要修改代码的逻辑,确保在赋值给Excel表格单元格之前将字典值转换为字符串或其他适当的数据类型。你可以使用str()方法将字典转换为字符串,然后再将字符串赋值给Excel单元格。例如:

cell_value = str(cell_value)
ws[f'{col_letter}{row_num}'] = cell_value

通过这样的方式,你可以处理字典值的转换问题,并将其正确地赋值给Excel表格单元格。

꧂代码 ꧁

import os
import glob
import openpyxl
from openpyxl.utils import get_column_letter
from openpyxl.styles import Font
from PIL import Image
from datetime import datetime


def process_image(image_path):
    img = Image.open(image_path)
    image_size = os.path.getsize(image_path)

    width, height = img.size
    color_info = get_color_info(img)

    return {
        '文件名': os.path.basename(image_path),
        '图片大小': format_size(image_size),
        '尺寸': f'{width}x{height}',
        '颜色类型': color_info['types'],
        '占比信息': color_info['proportions']
    }


def get_color_info(img):
    # 获取图片像素信息
    pixels = img.load()

    # 统计颜色的像素数量
    color_counts = {}
    total_pixels = img.width * img.height
    for i in range(img.width):
        for j in range(img.height):
            color = pixels[i, j]
            color_counts[color] = color_counts.get(color, 0) + 1

    # 计算每种颜色的占比
    color_info = {}
    for color, count in color_counts.items():
        proportion = count / total_pixels
        if proportion > 0.001:
            color_info[color] = proportion

    return {
        'types': len(color_info.keys()),
        'proportions': color_info
    }


def format_size(size):
    # 格式化文件大小
    sizes = ['B', 'KB', 'MB', 'GB']
    index = 0
    while size >= 1024 and index < len(sizes) - 1:
        size /= 1024
        index += 1
    return f'{round(size, 2)} {sizes[index]}'


def create_excel_table(data, table_path):
    wb = openpyxl.Workbook()
    ws = wb.active

    # 设置标题行的样式
    title_font = Font(bold=True)
    for col_num, column_title in enumerate(data[0].keys(), 1):
        col_letter = get_column_letter(col_num)
        ws[f'{col_letter}1'] = column_title
        ws[f'{col_letter}1'].font = title_font

    # 填充数据
    for row_num, row_data in enumerate(data, 2):
        for col_num, cell_value in enumerate(row_data.values(), 1):
#            col_letter = get_column_letter(col_num)
            
            cell_value = str(cell_value)
            ws[f'{col_letter}{row_num}'] = cell_value
            
    # 自动调整列宽
    for col_num, column_title in enumerate(data[0].keys(), 1):
        col_letter = get_column_letter(col_num)
        ws.column_dimensions[col_letter].auto_size = True

    # 保存表格
    wb.save(table_path)


def process_images(input_path):
    if os.path.isfile(input_path):
        image_files = [input_path]
    elif os.path.isdir(input_path):
        pattern = os.path.join(input_path, '**', '*.jpg')
        image_files = glob.glob(pattern, recursive=True)
    else:
        print("输入路径无效!")
        return

    image_data = []
    for image_file in image_files:
        try:
            image_info = process_image(image_file)
            image_data.append(image_info)
        except Exception as e:
            print(f"处理图片 {image_file} 时出错:{str(e)}")

    timestamp = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
    table_name = f"图片尺寸表格 ({timestamp}).xlsx"
    table_path = os.path.join('/storage/emulated/0/代码文件/excel/', table_name)

    create_excel_table(image_data, table_path)
    print("已创建图片尺寸表格:", table_path)


if __name__ == '__main__':
    input_path = input("请输入文件路径或文件夹路径:")
    process_images(input_path)
    
    
#添加检测:
# 新添加的代码
var = "hello"
print("type:", type(var))
print("value:", str(var))
#input("pause at line: {}".format(str(__fil e__.split("/")[-1])+": "+str(30)))
input("pause at line: {}".format(str(file.split("/")[-1]) + ": " + str(30)))
print("help:", help(type(var)))


꧂ 截图꧁

在这里插入图片描述

꧂错误信息 ꧁

❌❌❌❌❌❌❌❌❌❌❌

/data/user/0/org.qpython.qpy/files/bin/qpy thon3.sh "/storage/emulated/0/qpython/评论 截图问题1.矩阵2.1.2.1空行问题3.4.6色心6.6꧂ python图片:获得颜色占比,图片尺寸1.2保存表格1.1.py" && exit
比,图片尺寸1.2保存表格1.1.py" && exit   < 请输入文件路径或文件夹路径:/storage/emula ted/0/DCIM/1696948008360.pngTraceback (most recent call last):  File "/storage/emulated/0/qpython/评论截 图问题1.矩阵2.1.2.1空行问题3.4.6色心6.6꧂py thon图片:获得颜色占比,图片尺寸1.2保存表格1.1.py", line 117, in <module>    process_images(input_path)  File "/storage/emulated/0/qpython/评论截 图问题1.矩阵2.1.2.1空行问题3.4.6色心6.6꧂py thon图片:获得颜色占比,图片尺寸1.2保存表格1.1.py", line 111, in process_images    create_excel_table(image_data, table_p ath)  File "/storage/emulated/0/qpython/评论截 图问题1.矩阵2.1.2.1空行问题3.4.6色心6.6꧂py thon图片:获得颜色占比,图片尺寸1.2保存表格1.1.py", line 86, in create_excel_table    wb.save(table_path)  File "/data/user/0/org.qpython.qpy/files /lib/python3.11/site-packages/openpyxl/wor kbook/workbook.py", line 386, in save    save_workbook(self, filename)  File "/data/user/0/org.qpython.qpy/files /lib/python3.11/site-packages/openpyxl/wri ter/excel.py", line 291, in save_workbook    archive = ZipFile(filename, 'w', ZIP_D EFLATED, allowZip64=True)              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^  File "/data/user/0/org.qpython.qpy/files /lib/python3.11/zipfile.py", line 1281, in  __init__    self.fp = io.open(file, filemode)              ^^^^^^^^^^^^^^^^^^^^^^^PermissionError: [Errno 1] Operation not p ermitted: '/storage/emulated/0/代码文件/ex cel/图片尺寸表格 (2023-10-11 11:45:43).xls x'1|:/ $

꧂GPT给出解读信息 ꧁

这是一个权限错误。根据错误信息的提示,你尝试在 /storage/emulated/0 目录下创建或写入文件,但是没有足够的权限进行操作。

解决这个问题需要检查你的代码中是否存在访问受限的文件或目录,并将其修改为具有读写权限的目录。你可以尝试将表格保存到其他目录中,例如 /storage/emulated/0/Documents/storage/emulated/0/Download 等具有读写权限的目录。另外,还需要检查你的应用程序是否已经获得了足够的权限来访问这些目录。

最后,你可以通过给目录授权来解决此问题。例如,使用以下命令来将 /storage/emulated/0/代码文件/excel 目录的所有权和权限设置为当前用户:

chmod -R 777 /storage/emulated/0/代码文件/excel

这将允许你的代码在该目录中创建和写入文件。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
这个错误提示表明在 header.proto 文件的第 7、24、35 行存在语法错误。根据错误提示,第 7 和 35 行都是 "Expected type name",第 24 行是 "Missing field number"。这些错误通常表示你的 .proto 文件存在语法错误,编译器无法正确解析文件内容。 针对这些错误,你可以参考以下建议进行修复: 1. "Expected type name" 错误通常表示在定义消息体或枚举类型时,没有正确指定类型名称。例如,下面的代码就会导致这个错误: ``` message MyMessage { int32 = 1; } ``` 这里的 int32 应该是一个字段类型,而不是一个类型名称。正确的代码应该是: ``` message MyMessage { int32 my_field = 1; } ``` 在这个例子中,我们为字段指定了名称 my_field,并分配了字段编号 1。 2. "Missing field number" 错误通常表示在定义消息体或枚举类型时,没有为字段指定编号。每个字段都需要分配一个唯一的编号,用于在序列化和反序列化时识别不同的字段。例如,下面的代码就会导致这个错误: ``` message MyMessage { int32 my_field; } ``` 这里的 my_field 字段没有指定编号,应该修改为: ``` message MyMessage { int32 my_field = 1; } ``` 在这个例子中,我们为字段 my_field 指定了编号 1。 3. 如果以上步骤都不能解决问题,你可以尝试检查 .proto 文件中其他位置是否存在语法错误。可以使用文本编辑器打开文件,查找可能存在问题的位置,并修复语法错误。 希望这些步骤能够帮助你解决问题!
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值