python嵌
‘壹’ python 嵌套的列表推导式怎么理解的呢
5.1.4. 嵌套的列表推导式
列表解析中的第一个表达式可以是任何表达式,包括列表解析。
考虑下面有三个长度为 4 的列表组成的 3x4 矩阵:
>>> matrix = [
... [1, 2, 3, 4],
... [5, 6, 7, 8],
... [9, 10, 11, 12],
... ]
现在,如果你想交换行和列,可以用嵌套的列表推导式:
>>> [[row[i] for row in matrix] for i in range(4)]
[[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]
像前面看到的,嵌套的列表推导式是对 for 后面的内容进行求值,所以上例就等价于:
>>> transposed = []
>>> for i in range(4):
... transposed.append([row[i] for row in matrix])
...
>>> transposed
[[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]
反过来说,如下也是一样的:
>>> transposed = []
>>> for i in range(4):
... # the following 3 lines implement the nested listcomp
... transposed_row = []
... for row in matrix:
... transposed_row.append(row[i])
... transposed.append(transposed_row)
...
>>> transposed
[[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]
在实际中,你应该更喜欢使用内置函数组成复杂流程语句。对此种情况 zip() 函数将会做的更好:
>>> list(zip(*matrix))
[(1, 5, 9), (2, 6, 10), (3, 7, 11), (4, 8, 12)]
‘贰’ python 如何将图片嵌入表格
要将图片嵌入表格,可以使用 Python 的 openpyxl 库。
以下是一个例子:
from openpyxl import Workbook
from openpyxl.drawing.image import Image
# 创建一个新的工作簿
wb = Workbook()
ws = wb.active
# 将图片插入到指定的单元格
img = Image('A路径/图片.png')
ws.add_image(img, 'B2') # 在 B2 单元格中插入图片
# 保存工作簿
wb.save('表格.xlsx')
上述代码中,使用 openpyxl.drawing.image.Image 类加载本地图片,并使用 add_image 方法将其插入到指定的单元格中。
其中,add_image 方法的第一个参数是要插入的图片对象,第二个参数是要将图片插入到哪侍锋个单元格中。
在上面的例子中,我们将图片插入到了 B2 单元格中。如果需要插入到其他单元格,可以相应地修改第二个参数。
最后,调用 save 方法保存工作簿即可。请注意,为了使该晌码代码正常执行,您需要先安宴谈哪装 openpyxl 库。