使用torch.utils.data.TensorDataset封装数据集报错:

assert all(tensors[0].size(0) == tensor.size(0) for tensor in tensors)
AttributeError: 'Tensor' object has no attribute 'size'

是因为使用TensorDataset对数据集进行封装的时候,数据和标签必须是pytorch支持的tensor形式,而我输入的形式是numpy.ndarray和list形式,将其转换成tensor形式后,问题解决。格式转换使用torch.from_numpy和torch.Tensor方法即可,代码如下:

#读取训练数据集
train_data,train_labels = get_data(True)
train_data = train_data.reshape((50000, 3, 32, 32))
train_data = torch.from_numpy(train_data)
#print(type(train_labels)) #<class 'numpy.ndarray'>
train_labels = torch.from_numpy(train_labels)
#print(type(train_labels)) #<class 'torch.Tensor'>
train_dataset = torch.utils.data.TensorDataset(train_data,train_labels) #把数据放在数据库中
train_loader = torch.utils.data.DataLoader(dataset=train_dataset, batch_size = BATCH_SIZE, shuffle=True)  
print('读取训练数据集合完成')
test_data,test_labels = get_data(False)
test_data = test_data.reshape((10000, 3, 32, 32))
test_data = torch.from_numpy(test_data)
#print(type(test_labels))  #<class 'list'>
test_labels = torch.Tensor(test_labels) #list转换成tensor只能用这个方法
#print(type(test_labels))     #<class 'torch.Tensor'>
test_dataset = torch.utils.data.TensorDataset(test_data,test_labels) #把数据放在数据库中
test_loader = torch.utils.data.DataLoader(dataset=test_dataset, batch_size = BATCH_SIZE, shuffle=True)  
print('测试训练数据集合完成')

https://discuss.pytorch.org/t/assert-data-tensor-size-0-target-tensor-size-0-typeerror-int-object-is-not-callable/12850

https://stackoverflow.com/questions/53605586/answer/submit

使用torch.utils.data.TensorDataset封装数据集报错:assert all(tensors[0].size(0) == tensor.size(0) for tensor in tensors)AttributeError: 'Tensor' object has no attribute 'size'是因为使用TensorDataset对数据集进行封装的时候...
多线程爬虫出现报错 AttributeError : ‘NoneType’ object has no attribute ‘xpath’一、前言二、问题三、思考和解决问题四、运行效果 mark一下,本技术小白的第一篇CSDN博客! 最近在捣鼓爬虫,看的是机械工业出版社的《从零开始学Python网络爬虫》。这书吧,一言难尽,优点是案例比较多,说的也还算清楚,但是槽点更多:1、较多低级笔误;2、基础知识一笔带过,简单得不能再简单,对Python基础不好的人不友好;3、代码分析部分,相同的代码反复啰嗦解释多次,而一些该解释的新代码却只字不提;4、这是最重要的一点,但也不全是本书的锅。就是书中
@【KERAS】报错 AttributeError : ‘ Tensor object has no attribute ‘_keras_shape’ 【KERAS】 AttributeError : ‘ Tensor object has no attribute ‘_keras_shape’ ——解决方案 在用keras编写了Mish激活函数,构造BN_。 我们对Markdown编辑器进...
在执行代码时遇到了:的问题,代码如下: 而从字面上意思,就是int类型的对象没有参数,定位到代码:这里,也就是说node类型可能不是我们想要的node类型。这时候我通过调试发现,居然等于。 所以很明显,问题出在第一行代码:,而这看不错问题所在,因为enumerate正常遍历list类型,但是问题正好出在这,从刚才的调试结果发现其实是dict类型,而dict类型不能用来遍历,所以这就是问题所在,误用导致解析出的node是int类型的0,从而出现错误。解决方式也很简单,使用items()遍历:
报错 AttributeError : ' Tensor ' object has no attribute 'numpy' 解决:tf.enable_eager_execution() 拓展:获取 tensor 类型的变量值 方法一:在会话中print( sess.run(x) ) import tensor flow as tf #定义 tensor 常量 x = tf.random_uniform(...
可以看到np.random.randint(1,10)的前两个参数是low和high,没有第三个参数 size ,所以返回值是一个int类型的数字。而line接受的参数是ndarray类型,所以会报错。应该np.random.randint(1,10,1)确保生成ndarray类型。 注: tensor 类型也可以。还可以混用。 input1 = Input(shape(2,)) input2 = Input(shape(3,)) output = K.concatenate([input1,input2], axis=-1) model = Model(inputs=[input1,input2]
保存图片时老出错,查阅很多资料之后终于改好了: X = ( test_dataset[0] * 0.5 + 0.5 ) * 255 #归一化之后的图片数组,如果你的数组是正确的,就不需要归一化。 print(X)#输出x,观察自己的数组类型,我的是tf. Tensor 类型,所以张量转换类型很重要 img = tf.cast(X, dtype=tf.uint8)# 这一步转换张量数据类型很重要 img = tf.image.encode_png(img)# 编码回图片 第一个是 Tensor Flow的版本问题,要 Tensor Flow1.14以上版本才有,所以就解决方案就是升级 Tensor Flow到1.14以上版本 具体语句为pip install tensor flow==版本号 第二个原因,如果你升级了以后还是报错那么就添加以下语句tf.enable_eager_execution() 切换到eage