python读取数据集的方法_[宜配屋]听图阁

page-header-to-2021-08-21.jpg

如下所示:

# -*- coding: utf-8 -*-

# @ author hulei 2016-5-3

from numpy import *

import operator

from os import listdir

import sys

reload(sys)

sys.setdefaultencoding('utf8')

# x,y=getDataSet_dz('iris.data.txt',4)

def getDataSet(filename,numberOfFeature): #将数据集读入内存

fr = open(filename)

numberOfLines = len(fr.readlines()) #get the number of lines in the file file.readlines()是把文件的全部内容读到内存,并解析成一个list

returnMat = zeros((numberOfLines,numberOfFeature)) #prepare matrix to return 3代表数据集中特征数目###

classLabelVector = [] #prepare labels return

fr = open(filename)

index = 0

for line in fr.readlines():

line = line.strip() #strip() 参数为空时,默认删除空白符(包括'\n', '\r', '\t', ' ')

listFromLine = line.split(',') #split 以什么为标准分割一次 分成数组中的每个元素

returnMat[index,:] = listFromLine[0:numberOfFeature]

#classLabelVector.append(int(listFromLine[-1])) #append() 方法向列表的尾部添加一个新的元素

if listFromLine[-1] == 'Iris-setosa' :

classLabelVector.append(1)

elif listFromLine[-1] == 'Iris-versicolor' :

classLabelVector.append(2)

else:

#elif listFromLine[-1] == 'Iris-virginica' :

classLabelVector.append(3)

index += 1

return returnMat,classLabelVector

def getDataSet_dz(filename,numberOfFeature): #改进版,可以消除数据中的空白行

numberOfLines = 0

mx = [] #将数据集 去除空行后存入

fr = open(filename)

for line in fr.readlines():

line = line.strip()

if line != '' : #去除空白行

numberOfLines+=1

mx.append( line.split(',') )

returnMat = zeros((numberOfLines,numberOfFeature))

classLabelVector = []

for index in range(numberOfLines) :

returnMat[index,:] = mx[index][0:numberOfFeature]

if mx[index][-1] == 'Iris-setosa' :

classLabelVector.append(1)

elif mx[index][-1] == 'Iris-versicolor' :

classLabelVector.append(2)

else:

#elif listFromLine[-1] == 'Iris-virginica' :

classLabelVector.append(3)

return returnMat,classLabelVector

以上这篇Python读取数据集并消除数据中的空行方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持【听图阁-专注于Python设计】。

page-footer-to-2021-08-21.jpg

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值