- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试从一组形状或属性中生成 50 个随机的个人资料图像。有不同颜色背景的分组、矩形( body 的占位符)、圆形(头部)、椭圆形( ARM ),然后是一组数字。每个图像都有一个透明的背景,除了纯色的背景图像。所有图片均为 PNG。
目前,我正在运行一个 for 循环,生成一个随机数,并使用该数字运行函数来检索随机分类的属性图像。然后我使用 Image.paste 链将随机属性图像集放在一起并保存到外部文件夹。
问题是,一些生成的图像共享先前生成的图像的重叠属性。几乎就像没有重新分配变量一样。这是一个例子-
这是我正在使用的代码:
body1 = Image.open("test-images/body1.png")
# example of array of images
bodyArr = (body1, body2, body3, body4, body5, body6, body7, body8)
# example of function to select a position in above array
def getBody(num):
result = int(num[2:4])
if result < 12:
return 0
elif result >= 12 and result < 24:
return 1
elif result >= 24 and result < 36:
return 2
elif result >= 36 and result < 48:
return 3
elif result >= 48 and result < 60:
return 4
elif result >= 60 and result < 72:
return 5
elif result >= 72 and result < 84:
return 6
else:
return 7
for x in range(0, 50):
# generate random, 10 digit number
randomStr = str(randint(100000000000, 999999999999))[1:11]
# assigning images
backgroundImage = bgArr[getBg(randomStr)]
bodyImage = bodyArr[getBody(randomStr)]
headImage = headArr[getHead(randomStr)]
armsImage = armsArr[getArms(randomStr)]
numImage = numArr[getNum(randomStr)]
backgroundImage.paste(bodyImage, (0,0), bodyImage)
backgroundImage.paste(headImage, (0,0), headImage)
backgroundImage.paste(armsImage, (0,0), armsImage)
backgroundImage.paste(numImage, (0,0), numImage)
imgname = f'{dirname}/profile_images/profile{x}.png'
backgroundImage.save(imgname)
知道是什么原因造成的吗?我尝试使用多个 Image.show() 进行调试以查看哪里出错了,但是在方法中设置“title”参数在预览中不起作用并且很难获得完整的时间线。
感谢您的帮助!
最佳答案
在 for 循环中,您正在从 bgArr[getBg(randomStr)]
获取 backgroundImage
的浅拷贝。这意味着,您正在使用之前可能已修改的相同对象。
你能试试deepcopy
吗?
import copy
# ...
for x in range(0, 50):
#...
# assigning images
backgroundImage = copy.deepcopy(bgArr[getBg(randomStr)])
来自 python doc , 我们看到
Assignment statements in Python do not copy objects, they create bindings between a target and an object. For collections that are mutable or contain mutable items, a copy is sometimes needed so one can change one copy without changing the other.
A deep copy constructs a new compound object and then, recursively, inserts copies into it of the objects found in the original.
关于python - 为什么在 for 循环中使用 PIL 的 Image.paste 时出现图像重叠问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67797147/
在 python 解释器中: >>> import PIL >>> PIL.Image Traceback (most recent call last): File "", line 1, in
我在 Pillow 中遇到过这个奇怪的错误,其中导入名称 PIL 需要全部小写而不是全部大写,但我从未见过 pil在任何地方都使用小写字母。这意味着我使用的导入 PIL 的所有 python 包和文件
有没有办法使用 PIL 截取驻留在我的服务器上的指定 HTML/Javascript 页面的屏幕截图? 我想编写一个脚本来更改该 HTML 页面上的一些参数,然后让 PIL 对其进行屏幕截图。 有什么
这是我所做的描述。 我正在尝试使用 PIL 编写程序,但是在尝试导入它时(如下所示),出现错误(也如下所示)。 from PIL import Image Here is the error. Tra
我正在尝试对图像进行简单的裁剪。这是代码 from PIL.Image import Image def get_image_half(image, half="upper"): if hal
我是一名新的Python用户,也是“Stack Overflow”中的新用户,当我尝试编译 tensorflow 代码时,我遇到了一些问题,并且我无法从网站上找到答案,所以我想从这里获得一些帮助,先谢
我知道 stackoverflow 上已经有很多与此问题相关的问题,我已经阅读了所有问题,但我仍然没有成功解决此问题。我希望有人能帮我解决这个问题。 我已经安装并重新安装了 Pillow 10 次。我
我得到错误: --------------------------------------------------------------------------- ImportError
我是机器学习的初学者,所以我试图创建一个模型来识别 Keras 博客中引用的图像。我已经在 Windows 10 上安装了 Anaconda 3 以及所有软件包,如tensorflow、keras、s
我正在尝试使用过滤器 FIND_EDGES 从图片中获取边缘,它在我的 Windows PC 上工作,但是当我在我的 Raspberry Pi 上运行相同的代码时,它给出了图像模式错误的错误。 最佳答
这个问题在 Python 环境中有一些答案,但这些解决方案不适用于我的 RStudio 环境。这是我的代码: library(keras) library(tensorflow) use_condae
我正在使用 Mac OS x 10.10.3 Yosemite 和 Python 2.7.9 |Anaconda 2.2.0 (x86_64) 来处理很多 python 的东西。我正在使用 Eclip
我正在遵循这个 SageMaker 指南并使用 1.12 cpu docker 文件。 https://github.com/aws/sagemaker-tensorflow-serving-cont
`from PIL import Image, ImageDraw, ImageFont image = Image.new('RGB', (950, 250), color=(255, 255, 2
我知道如何从图片中找到边缘。但我希望轮廓边缘更厚,例如宽度 9。 from PIL import Image, ImageFilter image = Image.open('your
我有多个白色背景的 PNG 图像,并且图像的某些部分充满了图案(可能是不同的颜色,黑色、蓝色、红色、黄色等)。 如何使用 Python PIL 库将所有这些图像合并为一张图像,以便所有非白色部分出
目前我正在尝试裁剪以下地址下文件夹内的所有图像:C:\\Users\\xie\\Desktop\\tiff\\Bmp然后将它们重新保存到同一个文件夹中。下面是我试图试验的代码,两者都运行没有错误但什么
虽然它们非常相似,但我确信 Pearson 相关相似度和调整余弦相似度之间存在一些差异,因为所有的论文和网页都将它们分为两种不同的类型。 然而,它们都没有提供明确的定义。 Here是其中一页。 谁能说
这是我的forms.py: class UploadImageForm(forms.ModelForm): class Meta: model = UserImages
关闭。这个问题需要更多 focused .它目前不接受答案。 想改进这个问题?更新问题,使其仅关注一个问题 editing this post . 4年前关闭。 Improve this questi
我是一名优秀的程序员,十分优秀!