动手学数据分析-Task01

1 第一章:数据加载

1.1 载入数据

1.1.1 任务一:导入numpy和pandas

import numpy as np
import pandas as pd

1.1.2 任务二:载入数据

(1) 使用相对路径载入数据

df = pd.read_csv('./第一单元项目集合/train.csv')#采用相对路径,避免由于文件位置发生变动造成的问题
print(df.head(3))#读取数据的前三行

运行结果为:

PassengerIdSurvivedPclassFareCabinEmbarked
1037.2500NaNS
21171.2833C85C
3137.9250NaNS

[3 rows x 12 columns]

1.1.3 任务三:每1000行为一个数据模块,逐块读取

chunker = pd.read_csv('./第一单元项目集合/train.csv', chunksize=1000)

1.1.4 任务四:将表头改成中文,索引改为乘客ID [对于某些英文资料,我们可以通过翻译来更直观的熟悉我们的数据]

PassengerId => 乘客ID
Survived => 是否幸存
Pclass => 乘客等级(1/2/3等舱位)
Name => 乘客姓名
Sex => 性别
Age => 年龄
SibSp => 堂兄弟/妹个数
Parch => 父母与小孩个数
Ticket => 船票信息
Fare => 票价
Cabin => 客舱
Embarked => 登船港口

df = pd.read_csv('./第一单元项目集合/train.csv', names=['乘客ID','是否幸存','仓位等级','姓名','性别','年龄','兄弟姐妹个数','父母子女个数','船票信息','票价','客舱','登船港口'],index_col='乘客ID',header=0)
print(df.head())
乘客ID是否幸存仓位等级客舱登船港口
103NaNS
211C85C
313NaNS
411C123S
503NaNS

1.2 初步观察

导入数据后,你可能要对数据的整体结构和样例进行概览,比如说,数据大小、有多少列,各列都是什么格式的,是否包含null等

1.2.1 任务一:查看数据的基本信息

print(df.info())

<class ‘pandas.core.frame.DataFrame’>
Int64Index: 891 entries, 1 to 891
Data columns (total 11 columns):
# Column Non-Null Count Dtype


0是否幸存891non-nullint64
1仓位等级891non-nullint64
2姓名891non-nullobject
3性别891non-nullobject
4年龄714non-nullfloat64
5兄弟姐妹个数891non-nullint64
6父母子女个数891non-nullint64
7船票信息891non-nullobject
8票价891non-nullfloat64
9客舱204non-nullobject
10登船港口889non-nullobject

dtypes: float64(2), int64(4), object(5)
memory usage: 83.5+ KB
None

1.2.2 任务二:观察表格前10行的数据和后15行的数据

df.head(10)#前10行的数据
df.tail(15)#后15行的数据

1.2.4 任务三:判断数据是否为空,为空的地方返回True,其余地方返回False

df.isnull().head(3)#打印前三行数据是否为空的结果
print(df.isnull().any())  # 列级别的判断,只要该列有为空或者NA的元素,返回结果为布尔值,为True or Fals
print(df[df.isnull().values==True])#可以只显示存在缺失值的行列,清楚的确定缺失值的位置。
print(df.isnull().sum())#将列中为空的个数统计出来
是否幸存0
仓位等级0
姓名0
性别0
年龄177
兄弟姐妹个数0
父母子女个数0
船票信息0
票价0
客舱687
登船港口2

1.3 保存数据

1.3.1 任务一:将你加载并做出改变的数据,在工作目录下保存为一个新文件train_chinese.csv

df.to_csv('train_chinese.csv')#保存到当前目录
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值