ValueError:没有为“dense_input”提供数据

2024-05-16

我正在使用以下简单的代码使用tensorflow加载csv并使用keras执行建模...

无法弄清楚这个错误!

import tensorflow as tf

train_dataset_fp = tf.keras.utils.get_file(fname=file_path, origin=URL)
columns = ["X","Y"]

features = columns[:-1]
labels = columns[-1]

batch_size = 32

train_dataset = tf.data.experimental.make_csv_dataset(
    train_dataset_fp,
    batch_size,
    column_names = columns,
    label_name= labels,
    num_epochs=1
)

data_iterator = train_dataset.make_one_shot_iterator()

X_train, Y_train = data_iterator.get_next()

from tensorflow import keras

model = keras.Sequential([
    keras.layers.Dense(10, input_shape=[len(X_train)]),
    keras.layers.Dense(1)
])

model.compile(loss='mse',
                optimizer='adam',
                metrics=['mae', 'mse'])

model.summary()

model.fit(X_train, Y_train, epochs=1000, steps_per_epoch=batch_size)

虽然代码的其余部分工作正常,但我无法弄清楚为什么我会遇到密集的输入错误。

如果使用 pandas,相同的代码可以完美地工作,我试图消除对其他库的依赖,因此使用张量流组件,但似乎失败了。

_________________________________________________________________
Layer (type)                 Output Shape              Param #   
=================================================================
dense (Dense)                (None, 10)                30        
_________________________________________________________________
dense_1 (Dense)              (None, 1)                 11        
=================================================================
Total params: 41
Trainable params: 41
Non-trainable params: 0
_________________________________________________________________
Traceback (most recent call last):
  File "/Users/abhinavasrivastava/anaconda3/envs/ml/lib/python3.6/site-packages/tensorflow/python/keras/engine/training_utils.py", line 267, in standardize_input_data
    for x in names
  File "/Users/abhinavasrivastava/anaconda3/envs/ml/lib/python3.6/site-packages/tensorflow/python/keras/engine/training_utils.py", line 267, in <listcomp>
    for x in names
KeyError: 'dense_input'

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "simple_linear_keras.py", line 47, in <module>
    model.fit(X_train, Y_train, epochs=1000, callbacks=[tb], steps_per_epoch=batch_size)
  File "/Users/abhinavasrivastava/anaconda3/envs/ml/lib/python3.6/site-packages/tensorflow/python/keras/engine/training.py", line 1536, in fit
    validation_split=validation_split)
  File "/Users/abhinavasrivastava/anaconda3/envs/ml/lib/python3.6/site-packages/tensorflow/python/keras/engine/training.py", line 992, in _standardize_user_data
    class_weight, batch_size)
  File "/Users/abhinavasrivastava/anaconda3/envs/ml/lib/python3.6/site-packages/tensorflow/python/keras/engine/training.py", line 1117, in _standardize_weights
    exception_prefix='input')
  File "/Users/abhinavasrivastava/anaconda3/envs/ml/lib/python3.6/site-packages/tensorflow/python/keras/engine/training_utils.py", line 271, in standardize_input_data
    'for each key in: ' + str(names))
ValueError: No data provided for "dense_input". Need data for each key in: ['dense_input']

错误No data provided for "dense_input"意味着 Keras 根本没有获取输入数据,或者没有以预期的格式获取输入数据,即以数组的形式获取,在 Python 中意味着 numpy 数组。

假设其他一切正常,那么只需添加一行来转换 X_train 和 Y_train 应该会有所帮助:

import numpy as np
X_train = np.array(X_train)
Y_train = np.array(Y_train)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

ValueError:没有为“dense_input”提供数据 的相关文章

  • 如何使用显式引用转储 YAML?

    递归引用非常适合ruamel yaml or pyyaml ruamel yaml dump ruamel yaml load A A id001 id001 然而 它 显然 不适用于普通引用 ruamel yaml dump ruamel
  • 为什么我的代码不能根据字典解码加密字符串?

    我有一本字典 其中包含代表字母的键和值 例如一个简单的 DICT CODE b g n a p o x d t y 我收到了一个加密代码 并将该字符串转换为一个列表 其中每个项目都是一个单词 我需要根据字典中的项目来解决它 代码示例是 wo
  • 了解 Python 中的酸洗

    我最近接到一项作业 需要以腌制形式放置一本字典 其中每个键引用一个列表 唯一的问题是我不知道腌制形式是什么 谁能给我指出一些好的资源的正确方向来帮助我学习这个概念 pickle 模块实现了一个基本但强大的算法 用于序列化和反序列化 Pyth
  • 查找模块中显式定义的函数 (python)

    好的 我知道您可以使用 dir 方法列出模块中的所有内容 但是有什么方法可以仅查看该模块中定义的函数吗 例如 假设我的模块如下所示 from datetime import date datetime def test return Thi
  • numpy 使用 datetime64 进行数字化

    我似乎无法让 numpy digitize 与 datetime64 一起使用 date bins np array np datetime64 datetime datetime 2014 n 1 s for n in range 1 1
  • 如何将 self 传递给装饰器?

    我该如何通过self key下面进入装饰器 class CacheMix object def init self args kwargs super CacheMix self init args kwargs key func Cons
  • 更改 python tkinter canvas 中的线坐标

    我画了一条线tkinter Canvas现在我想移动一端 这可能吗 例如和itemconfig import tkinter tk tkinter Tk canvas tkinter Canvas tk canvas pack line c
  • python 中的 Johansen 协整检验

    我找不到任何有关在处理统计和时间序列分析 pandas 和 statsmodel 的 Python 模块中执行 Johansen 协整检验的功能的参考 有谁知道是否有一些代码可以执行时间序列之间的协整测试 现在 这已在 Python 的 s
  • `list()` 被认为是一个函数吗?

    list显然是内置类型 https docs python org 3 library stdtypes html list在Python中 我看到底下有一条评论this https stackoverflow com a 53645813
  • 如何使用 Django 项目设置 SQLite?

    我已阅读 Django 文档 仅供参考 https docs djangoproject com en 1 3 intro tutorial01 https docs djangoproject com en 1 3 intro tutor
  • django-admin.py makemessages 不起作用

    我正在尝试翻译一个字符串 load i18n trans Well Hello there how are you to Hola amigo que tal 我的 settings py 文件有这样的内容 LOCALE PATHS os
  • 乘以行并按单元格值附加到数据框

    考虑以下数据框 df pd DataFrame X a b c d Y a b d e Z a b c d 1 2 1 3 df 我想在 列中附加数字大于 1 的行 并在该行中的数字减 1 df 最好应该 然后看起来像这样 或者它可能看起来
  • Python 惰性迭代器

    我试图了解迭代器表达式如何以及何时被求值 以下似乎是一个懒惰的表达 g i for i in range 1000 if i 3 i 2 然而 这个在构造上失败了 g line strip for line in open xxx r if
  • 如何使用 paramiko 查看(日志)文件传输进度?

    我正在使用 Paramiko 的 SFTPClient 在主机之间传输文件 我希望我的脚本打印文件传输进度 类似于使用 scp 看到的输出 scp my file user host user host password my file 1
  • 处理大文件的最快方法?

    我有多个 3 GB 制表符分隔文件 每个文件中有 2000 万行 所有行都必须独立处理 任何两行之间没有关系 我的问题是 什么会更快 逐行阅读 with open as infile for line in infile 将文件分块读入内存
  • 如何在 robobrowser-python 中发出 POST 请求

    http robobrowser readthedocs org en latest api html http robobrowser readthedocs org en latest api html 我正在尝试使用 APIbrows
  • 更改 Python Cmd 模块处理自动完成的方式

    我有一个 Cmd 控制台 设置为自动完成 Magic the Gathering 收藏管理系统的卡牌名称 它使用文本参数在数据库中查询卡片 并使用结果自动完成 建议卡片 然而 这些卡片名称有多个单词 Cmd 会从last到行尾的空间 例如
  • 如何为所有用户安装 Anaconda python?

    Anaconda python 发行版 https store continuum io cshop anaconda 非常方便地部署科学计算环境 SCE 并根据需要切换python版本 默认情况下 安装会将 python 定位到 anac
  • python sklearn中的fit方法

    我问自己关于 sklearn 中拟合方法的各种问题 问题1 当我这样做时 from sklearn decomposition import TruncatedSVD model TruncatedSVD svd 1 model fit X
  • 如何获取所有mysql元组结果并转换为json

    我能够从表中获取单个数据 但是当我试图获取表上的所有数据时 我只得到一行 cnn execute sql rows cnn fetchall column t 0 for t in cnn description for row in ro

随机推荐