鱼C论坛

 找回密码
 立即注册
查看: 2250|回复: 1

[已解决]Python一直报错找不到问题

[复制链接]
发表于 2023-9-15 16:34:56 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
代码一直报错:'str' object has no attribute 'rows',不知道到底啥问题?
  1. import openpyxl
  2. from PIL import ImageGrab

  3. # 打开 Excel 文件
  4. workbook = openpyxl.load_workbook(r'C:\Users\Administrator\Desktop\text.xlsx')

  5. # 选择要截图的工作表
  6. worksheet = workbook['试试']

  7. # 定义截图区域的坐标
  8. left, upper, right, lower = 0, 0, 2, 9

  9. # 获取工作表的尺寸
  10. rows, cols = worksheet.dimensions.rows, worksheet.dimensions.cols
  11. # 创建一个与工作表相同尺寸的图像
  12. image = ImageGrab.grab(bbox=(left, upper, right, lower))

  13. # 保存图像到文件
  14. image. Save('example.png')
复制代码
最佳答案
2023-9-15 16:35:05
代码中出现了错误,因为在获取工作表的尺寸时,使用了 worksheet.dimensions.rows ,但是 worksheet.dimensions 返回的是一个字符串类型,而字符串类型没有 rows 属性。可以使用 worksheet.max_row 和 worksheet.max_column 来获取工作表的最大行数和最大列数。

修改后的代码如下:

  1. import openpyxl
  2. from PIL import ImageGrab

  3. # 打开 Excel 文件
  4. workbook = openpyxl.load_workbook(r'C:\Users\Administrator\Desktop\text.xlsx')

  5. # 选择要截图的工作表
  6. worksheet = workbook['试试']

  7. # 定义截图区域的坐标
  8. left, upper, right, lower = 0, 0, 2, 9

  9. # 获取工作表的尺寸
  10. rows, cols = worksheet.max_row, worksheet.max_column
  11. # 创建一个与工作表相同尺寸的图像
  12. image = ImageGrab.grab(bbox=(left, upper, right, lower))

  13. # 保存图像到文件
  14. image.save('example.png')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-9-15 16:35:05 | 显示全部楼层    本楼为最佳答案   
代码中出现了错误,因为在获取工作表的尺寸时,使用了 worksheet.dimensions.rows ,但是 worksheet.dimensions 返回的是一个字符串类型,而字符串类型没有 rows 属性。可以使用 worksheet.max_row 和 worksheet.max_column 来获取工作表的最大行数和最大列数。

修改后的代码如下:

  1. import openpyxl
  2. from PIL import ImageGrab

  3. # 打开 Excel 文件
  4. workbook = openpyxl.load_workbook(r'C:\Users\Administrator\Desktop\text.xlsx')

  5. # 选择要截图的工作表
  6. worksheet = workbook['试试']

  7. # 定义截图区域的坐标
  8. left, upper, right, lower = 0, 0, 2, 9

  9. # 获取工作表的尺寸
  10. rows, cols = worksheet.max_row, worksheet.max_column
  11. # 创建一个与工作表相同尺寸的图像
  12. image = ImageGrab.grab(bbox=(left, upper, right, lower))

  13. # 保存图像到文件
  14. image.save('example.png')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-22 17:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表