python - 将列表 numpy 数组转换为 CNN-Keras 的普通数组
问题描述
我有一些由文件夹分隔的图像。所以我导入了它们并将它们转换为像素数组。当我输入:
In [9]: X_train.shape
out [9]: (7467,60,80,3)
我想在这个后面加上没有。类,创建一个数据集并保存为.json
文件并导入一个新的笔记本并为我自己的项目目的进行图像处理。所以我输入了这段代码:
In [10]: dataset = pd.DataFrame({'label': y_train, 'images': list(X_train)},
columns=['label', 'images'])
但是,当我输入:
In [11]: X_train
Out [11]: array([[[0., 0., 0.],
[0., 0., 0.],
[0., 0., 0.],
...,
[0., 0., 0.],
[0., 0., 0.],
[0., 0., 0.]],
[[0., 0., 0.],
[0., 0., 0.],
[0., 0., 0.],
...,
[0., 0., 0.],
[0., 0., 0.],
[0., 0., 0.]],
[[0., 0., 0.],
[0., 0., 0.],
[0., 0., 0.],
...,
[0., 0., 0.],
[0., 0., 0.],
[0., 0., 0.]],
...,
但是当我导入 json 文件并显示时:
In [2]: train=pd.read_json('train_file.json')
train.head()
Out [2]:
image_no images
0 7468 [[[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0039215...
1 7469 [[[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0,...
10 7478 [[[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0,...
100 7568 [[[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0,...
1000 8468 [[[0.27058823530000004, 0.1843137255, 0.247058.
..
当我输入:
In [3]: train['images].values
Out [3]: array([list([[[0.7411764706, 0.7607843137, 0.8274509804], `[0.7215686275000001, 0.7058823529, 0.7882352941], [0.7019607843, 0.6823529412, 0.7843137255], [0.7176470588, 0.7215686275000001, 0.8196078431], [0.8, 0.8352941176, 0.8549019608], [0.8352941176, 0.8666666667, 0.8666666667], [0.8509803922, 0.8745098039, 0.8666666667], [0.8549019608, 0.8745098039, 0.8666666667], [0.8431372549, 0.8666666667, 0.8666666667], [0.8235294118, 0.8705882353000001, 0.8588235294000001], [0.831372549, 0.8705882353000001, 0.8627450980000001], [0.8352941176, 0.831372549, 0.8549019608], [0.7686274510000001, 0.7686274510000001, 0.8117647059], [0.7098039216, 0.7254901961, 0.7803921569000001], [0.7019607843, 0.7333333333000001, 0.8], [0.7254901961, 0.7686274510000001, 0.8392156863], [0.7647058824, 0.7803921569000001, 0.8509803922], [0.7372549020000001, 0.7411764706, 0.8117647059], [0.7098039216, 0.7019607843, 0.7960784314], [0.6980392157, 0.6705882353, 0.8039215686000001], [0.6901960784000001, 0.6823529412, 0.8117647059], [0.6901960784000001, 0.6901960784000001, 0.8196078431], [0.6941176471, 0.6980392157, 0.831372549], [0.6980392157, 0.7058823529, 0.8352941176], [0.7254901961, 0.7490196078, 0.8352941176], [0.8, 0.831372549, 0.8745098039], [0.8431372549, 0.8784313725, 0.8862745098], [0.8509803922, 0.8823529412000001, 0.8862745098], [0.831372549, 0.8352941176, 0.8745098039], [0.7725490196, 0.7411764706, 0.8392156863], [0.7529411765, 0.7294117647, 0.8392156863], [0.7607843137, 0.7764705882, 0.8352941176], [0.8078431373, 0.8392156863, 0.8705882353000001], [0.8274509804, 0.8549019608, 0.8862745098], [0.8117647059, 0.8431372549, 0.8705882353000001], [0.7725490196, 0.8, 0.8352941176], [0.7529411765, 0.7764705882, 0.8431372549], [0.8117647059, 0.8352941176, 0.8862745098], [0.8745098039, 0.8980392157, 0.9176470588000001], [0.8862745098, 0.9098039216, 0.9058823529000001], [0.8823529412000001, 0.9058823529000001, 0.9019607843], [0.8784313725, 0.9098039216, 0.9058823529000001], [0.8666666667, 0.9137254902, 0.9058823529000001], [0.8627450980000001, 0.9176470588000001, 0.9098039216], [0.86274509....`
当我输入:
In [4]: train['images'].shape
Out [4]: (7467,)
但我可以使用plt.imshow()
. 但是当我尝试直接做model.fit(train['images],y_train)
我得到这个错误:
ValueError:使用序列设置数组元素
那么我哪里错了?在将其转储到文件时,或者在导入文件并修复错误.json
后如何将其转换为数组。json
解决方案
np arrays
将数据框存储为.json
. 要将它们提供给您的 Keras 模型,您需要使它们具有以下array
形状之一(images, height, width, channels)
:
X_train = np.array(train['images'].tolist())
推荐阅读
- winapi - WaitForSingleObject() 在未发生等待事件的情况下发出信号
- python - 从 API 中迭代 JSON 以获取第一个 True 数字?py2.7
- javascript - 从 JQUERY/AJAX 到 Morris.JS 的数据
- javascript - 绘图选项在可变半径饼图中不起作用
- python - 使用切片 arr[::-1] 反转具有两位数和三位数的字符串
- java - android.content.Context.getPackageName()' 在空对象引用上,当尝试通过 java 类访问活动中的方法时
- amazon-web-services - 批量 S3 事件触发的 AWS Glue ETL 作业
- regex - 正则表达式省略字符串之间的特定单词
- node.js - 如何将抓取的数据发送到索引 html 文件以加载
- python - 挂载作业输出数据作为 Floydhub 中另一个作业的输入数据