• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

《数据科学:R语言实现》——3.3 转换数据类型

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本节书摘来自华章计算机《数据科学:R语言实现》一书中的第3章,第3.3节,作者 丘祐玮(David Chiu),更多章节内容可以访问云栖社区“华章计算机”公众号查看。

3.3 转换数据类型

如果我们在数据导入阶段不指定数据类型,R会自动地给导入的数据集分配一个数据类型。但是,如果分配的数据类型和事实不符,我们可能会在后续的数据操作中遇到困难。因此数据类型转换是预处理阶段的基础性任务。

准备工作

完成之前的教程,导入employees.csv和salaries.csv给R进程。你必须给两个数据集指定了列名,以便执行下面的步骤。

实现步骤

执行下列步骤,转换数据类型。

1.首先,使用函数class查看每个属性的数据类型:

2.你也可以使用函数str查看所有属性的数据类型:

3.然后,你需要把birth_date和hire_date转换为日期格式:

4.你也需要把first_name和last_name转换为字符类型:

5.你可以再次使用str查看数据集:

6.而且,你可以把salaries中的from_date和to_date类型转换为日期类型:

运行原理

在本教程中,我们展示了如何对数据集中的每个属性进行数据类型转换。在进行转换之前,你必须首先查看每个属性的当前类型。为了确认数据类型,你可以使用函数class进行属性的类别判断。进一步,你可以使用函数str查看所有数据类型。

通过将函数str应用到employees数据框的输出,我们可以看到birth_date和hire_date都是因子类型的。但是,如果想通过birth_date属性计算一个人的年龄,就需要把它转换成日期格式。所以,我们使用函数as.Date把birth_date和hire_date都转换成日期格式。

而且,因子类型限制了属性在取值上的选择,我们并不能自由地给数据集添加记录。由于从数据集中准确地找到相同的姓和名并不容易,我们需要把last_name和first_name转换成字符类型。然后,在下一篇教程中,我们可以继续给数据集employees添加新的记录。最后,我们也应该把salaries数据集中的from_date和to_date转换成日期类型,以便在下一篇教程中进行日期计算。

更多技能

除了使用as函数转换数据类型,你也可以在数据导入阶段指定数据类型。以函数read.csv为例,你可以在colClasses参数中指定数据类型。如果你希望R自动地选择数据类型(即自动把emp_no转换为整型),只需要在colClasses中指明NA:

通过指定colClasses参数,emp_no、birth_date、first_name、last_name、gender和hire_date会分别转换成整型、日期类型、字符类型、字符类型、因子类型和日期类型。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
R语言进行文件夹操作示例(转)发布时间:2022-07-18
下一篇:
R语言回归模型中的训练集和测试集划分发布时间:2022-07-18
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap