本文并不表示R在数据分析方面比Python更好或更快速,我本人每天都使用两种语言。这篇文章只是提供了比较这两种语言的机会。
CSV文件包含纽约市的311条投诉。它是纽约市开放数据门户网站中最受欢迎的数据集。
“纽约市开放数据门户网站” 是一个特定的平台,用于提供各种数据资源。
运用大数据分析的方法对纽约市的 311 万条投诉进行研究。
具体可能包括对投诉内容进行分类、统计不同类型投诉的数量、分析投诉的趋势随时间的变化、挖掘投诉集中的区域等,
以更好地了解纽约市在各个方面存在的问题以及市民的关切点,为城市管理和决策提供依据。
本文中的 数据 每天都会更新,我的文件版本更大,为4.63 GB。
数据工作流程
install.packages("devtools")
library("devtools")
install_github("ropensci/plotly")
data:image/s3,"s3://crabby-images/6c4cb/6c4cb45584bf4bf709da5d0fb9d63859d048d05f" alt=""
library(plotly)
data:image/s3,"s3://crabby-images/6c4cb/6c4cb45584bf4bf709da5d0fb9d63859d048d05f" alt=""
需要创建一个帐户以连接到plotly API。或者,可以只使用默认的ggplot2图形。
set_credentials_file("DemoAccount", "lr1c37zw81") ## Replace contents with your API Key
data:image/s3,"s3://crabby-images/6c4cb/6c4cb45584bf4bf709da5d0fb9d63859d048d05f" alt=""
使用dplyr在R中进行分析
data:image/s3,"s3://crabby-images/d0d27/d0d273875a8738221c5491293b3b4a9b4080e7ce" alt=""
想了解更多关于模型定制、辅导的信息?
介绍
假设已安装sqlite3(因此可通过终端访问)。
$ sqlite3 data.db # Create your database
$.databases # Show databases to make sure it works
$.mode csv
$.import <filename> <tablename>
# Where filename is the name of the csv & tablename is the name of the new database table
$.quit
data:image/s3,"s3://crabby-images/6c4cb/6c4cb45584bf4bf709da5d0fb9d63859d048d05f" alt=""
将数据加载到内存中。
library(readr)
# data.table, selecting a subset of columns
time_data.table <- system.time(fread('/users/ryankelly/NYC_data.csv',
select = c('Agency', 'Created Date','Closed Date', 'Complaint Type', 'Descriptor', 'City'),
showProgress = T))
data:image/s3,"s3://crabby-images/6c4cb/6c4cb45584bf4bf709da5d0fb9d63859d048d05f" alt=""
kable(data.frame(rbind(time_data.table, time_data.table_full, time_readr)))
data:image/s3,"s3://crabby-images/6c4cb/6c4cb45584bf4bf709da5d0fb9d63859d048d05f" alt=""
user.self | sys.self | elapsed | user.child | sys.child | |
---|---|---|---|---|---|
time_data.table | 63.588 | 1.952 | 65.633 | 0 | 0 |
time_data.table_full | 205.571 | 3.124 | 208.880 | 0 | 0 |
time_readr | 277.720 | 5.018 | 283.029 | 0 | 0 |
我将使用data.table读取数据。该 fread
函数大大提高了读取速度。
关于dplyr
默认情况下,dplyr查询只会从数据库中提取前10行。
library(dplyr) ## Will be used for pandas replacement
# Connect to the database
db <- src_sqlite('/users/ryankelly/data.db')
db
data:image/s3,"s3://crabby-images/e5b66/e5b66f7d1ea3247d41b1f78a56661e835a024e11" alt=""
数据处理的两个最佳选择(除了R之外)是:
- 数据表
- dplyr
预览数据
# Wrapped in a function for display purposes
head_ <- function(x, n = 5) kable(head(x, n))
head_(data)
data:image/s3,"s3://crabby-images/da4b3/da4b38035e301059688a927aac9090d325c9048f" alt=""
Agency | CreatedDate | ClosedDate | ComplaintType | Descriptor | City |
---|---|---|---|---|---|
NYPD | 04/11/2015 02:13:04 AM | Noise – Street/Sidewalk | Loud Music/Party | BROOKLYN | |
DFTA | 04/11/2015 02:12:05 AM | Senior Center Complaint | N/A | ELMHURST | |
NYPD | 04/11/2015 02:11:46 AM | Noise – Commercial | Loud Music/Party | JAMAICA | |
NYPD | 04/11/2015 02:11:02 AM | Noise – Street/Sidewalk | Loud Talking | BROOKLYN | |
NYPD | 04/11/2015 02:10:45 AM | Noise – Street/Sidewalk | Loud Music/Party | NEW YORK |
选择几列
ComplaintType | Descriptor | Agency |
---|---|---|
Noise – Street/Sidewalk | Loud Music/Party | NYPD |
Senior Center Complaint | N/A | DFTA |
Noise – Commercial | Loud Music/Party | NYPD |
Noise – Street/Sidewalk | Loud Talking | NYPD |
Noise – Street/Sidewalk | Loud Music/Party | NYPD |
ComplaintType | Descriptor | Agency |
---|---|---|
Noise – Street/Sidewalk | Loud Music/Party | NYPD |
Senior Center Complaint | N/A | DFTA |
Noise – Commercial | Loud Music/Party | NYPD |
Noise – Street/Sidewalk | Loud Talking | NYPD |
Noise – Street/Sidewalk | Loud Music/Party | NYPD |
Noise – Street/Sidewalk | Loud Talking | NYPD |
Noise – Commercial | Loud Music/Party | NYPD |
HPD Literature Request | The ABCs of Housing – Spanish | HPD |
Noise – Street/Sidewalk | Loud Talking | NYPD |
Street Condition | Plate Condition – Noisy | DOT |
使用WHERE过滤行
ComplaintType | Descriptor | Agency |
---|---|---|
Noise – Street/Sidewalk | Loud Music/Party | NYPD |
Noise – Commercial | Loud Music/Party | NYPD |
Noise – Street/Sidewalk | Loud Talking | NYPD |
Noise – Street/Sidewalk | Loud Music/Party | NYPD |
Noise – Street/Sidewalk | Loud Talking | NYPD |
使用WHERE和IN过滤列中的多个值
ComplaintType | Descriptor | Agency |
---|---|---|
Noise – Street/Sidewalk | Loud Music/Party | NYPD |
Noise – Commercial | Loud Music/Party | NYPD |
Noise – Street/Sidewalk | Loud Talking | NYPD |
Noise – Street/Sidewalk | Loud Music/Party | NYPD |
Noise – Street/Sidewalk | Loud Talking | NYPD |
在DISTINCT列中查找唯一值
随时关注您喜欢的主题
## City
## 1 BROOKLYN
## 2 ELMHURST
## 3 JAMAICA
## 4 NEW YORK
## 5
## 6 BAYSIDE
data:image/s3,"s3://crabby-images/09047/09047e88e6019049081f986e183bab381114da22" alt=""
使用COUNT(*)和GROUP BY查询值计数
# dt[, .(No.Complaints = .N), Agency]
#setkey(dt, No.Complaints) # setkey index's the data
q <- data %>% select(Agency) %>% group_by(Agency) %>% summarise(No.Complaints = n())
head_(q)
data:image/s3,"s3://crabby-images/41900/41900ed8443c2b7fe39d18f273b68b7959a64d7d" alt=""
Agency | No.Complaints |
---|---|
3-1-1 | 22499 |
ACS | 3 |
AJC | 7 |
ART | 3 |
CAU | 8 |
使用ORDER和-排序结果
交互版本:
静态版本:
data:image/s3,"s3://crabby-images/47a6b/47a6b3fc31d6fb153546e338bcf032a7cc2bcb71" alt=""
data:image/s3,"s3://crabby-images/8f561/8f561421306886d5d0e467d299663e962727b030" alt=""
data:image/s3,"s3://crabby-images/30976/3097660391af35fe9e8bc009eedaba043e550ff1" alt=""
数据库中有多少个城市?
# dt[, unique(City)]
q <- data %>% select(City) %>% distinct() %>% summarise(Number.of.Cities = n())
head(q)
data:image/s3,"s3://crabby-images/09758/09758d4b46a022bb2dd2694777526fc7941d271e" alt=""
## Number.of.Cities
## 1 1818
data:image/s3,"s3://crabby-images/000da/000da44eb031f3dce689c54b325cc562ddc0e01c" alt=""
让我们来绘制10个最受关注的城市
City | No.Complaints |
---|---|
BROOKLYN | 2671085 |
NEW YORK | 1692514 |
BRONX | 1624292 |
766378 | |
STATEN ISLAND | 437395 |
JAMAICA | 147133 |
FLUSHING | 117669 |
ASTORIA | 90570 |
Jamaica | 67083 |
RIDGEWOOD | 66411 |
- 用
UPPER
转换CITY格式。
CITY | No.Complaints |
---|---|
BROOKLYN | 2671085 |
NEW YORK | 1692514 |
BRONX | 1624292 |
766378 | |
STATEN ISLAND | 437395 |
JAMAICA | 147133 |
FLUSHING | 117669 |
ASTORIA | 90570 |
JAMAICA | 67083 |
RIDGEWOOD | 66411 |
投诉类型(按城市)
# Plot result
plt <- ggplot(q_f, aes(ComplaintType, No.Complaints, fill = CITY)) +
geom_bar(stat = 'identity') +
theme_minimal() + theme(axis.text.x = element_text(angle = 45, hjust = 1))
plt
data:image/s3,"s3://crabby-images/2b5e7/2b5e7f192484932d623a648f7e7a02ecfbd8bedd" alt=""
data:image/s3,"s3://crabby-images/b5480/b548011633a3992e45f79f3abe956d1f01337c1b" alt=""
data:image/s3,"s3://crabby-images/32e29/32e29ed96dbfd6aa8152b221f07802da97f3d229" alt=""
第2部分时间序列运算
提供的数据不适合SQLite的标准日期格式。
在SQL数据库中创建一个新列,然后使用格式化的date语句重新插入数据 创建一个新表并将格式化日期插入原始列名。
使用时间戳字符串过滤SQLite行:YYYY-MM-DD hh:mm:ss
# dt[CreatedDate < '2014-11-26 23:47:00' & CreatedDate > '2014-09-16 23:45:00',
# .(ComplaintType, CreatedDate, City)]
q <- data %>% filter(CreatedDate < "2014-11-26 23:47:00", CreatedDate > "2014-09-16 23:45:00") %>%
select(ComplaintType, CreatedDate, City)
head_(q)
data:image/s3,"s3://crabby-images/bd6db/bd6db4554126b9b6d11673d5c78b3f06f6b45c3b" alt=""
ComplaintType | CreatedDate | City |
---|---|---|
Noise – Street/Sidewalk | 2014-11-12 11:59:56 | BRONX |
Taxi Complaint | 2014-11-12 11:59:40 | BROOKLYN |
Noise – Commercial | 2014-11-12 11:58:53 | BROOKLYN |
Noise – Commercial | 2014-11-12 11:58:26 | NEW YORK |
Noise – Street/Sidewalk | 2014-11-12 11:58:14 | NEW YORK |
使用strftime从时间戳中拉出小时单位
# dt[, hour := strftime('%H', CreatedDate), .(ComplaintType, CreatedDate, City)]
q <- data %>% mutate(hour = strftime('%H', CreatedDate)) %>%
select(ComplaintType, CreatedDate, City, hour)
head_(q)
data:image/s3,"s3://crabby-images/522fa/522fa3cf857b0da7e2908903a652fe6769f35a01" alt=""
ComplaintType | CreatedDate | City | hour |
---|---|---|---|
Noise – Street/Sidewalk | 2015-11-04 02:13:04 | BROOKLYN | 02 |
Senior Center Complaint | 2015-11-04 02:12:05 | ELMHURST | 02 |
Noise – Commercial | 2015-11-04 02:11:46 | JAMAICA | 02 |
Noise – Street/Sidewalk | 2015-11-04 02:11:02 | BROOKLYN | 02 |
Noise – Street/Sidewalk | 2015-11-04 02:10:45 | NEW YORK | 02 |
data:image/s3,"s3://crabby-images/9cd60/9cd606e50e22ba6f17292efcf64dcaae63fee80e" alt=""
data:image/s3,"s3://crabby-images/42626/426265f43801187a40906b14ed03a212a83294c1" alt=""
data:image/s3,"s3://crabby-images/32c22/32c228706ff7643bd553c89b955ca42f07d9158d" alt=""
data:image/s3,"s3://crabby-images/89188/8918877ccca07c2725d616a4f44456e8c3acc6ab" alt=""
data:image/s3,"s3://crabby-images/5923a/5923a44e8c3dcd22463c97793d80ca8c2e433e23" alt=""
data:image/s3,"s3://crabby-images/8b6de/8b6de044258738e961dad9eac23c0be145c8488d" alt=""
汇总时间序列
首先,创建一个时间戳记四舍五入到前15分钟间隔的新列
# Using lubridate::new_period()
# dt[, interval := CreatedDate - new_period(900, 'seconds')][, .(CreatedDate, interval)]
q <- data %>%
mutate(interval = sql("datetime((strftime('%s', CreatedDate) / 900) * 900, 'unixepoch')")) %>%
select(CreatedDate, interval)
head_(q, 10)
data:image/s3,"s3://crabby-images/b747c/b747c64007becfb9f375a6f238082076b6dbd6c2" alt=""
CreatedDate | interval |
---|---|
2015-11-04 02:13:04 | 2015-11-04 02:00:00 |
2015-11-04 02:12:05 | 2015-11-04 02:00:00 |
2015-11-04 02:11:46 | 2015-11-04 02:00:00 |
2015-11-04 02:11:02 | 2015-11-04 02:00:00 |
2015-11-04 02:10:45 | 2015-11-04 02:00:00 |
2015-11-04 02:09:07 | 2015-11-04 02:00:00 |
2015-11-04 02:05:47 | 2015-11-04 02:00:00 |
2015-11-04 02:03:43 | 2015-11-04 02:00:00 |
2015-11-04 02:03:29 | 2015-11-04 02:00:00 |
2015-11-04 02:02:17 | 2015-11-04 02:00:00 |
绘制2003年的结果
data:image/s3,"s3://crabby-images/2acda/2acda0ab1d1d7897ea7842ca6aafbb91757eb7a6" alt=""
data:image/s3,"s3://crabby-images/11fb2/11fb2fa21779f3acd29153165182b8385811a826" alt=""
data:image/s3,"s3://crabby-images/0ff9e/0ff9ebfce24b71168727fb03e9b09fe7adad6efc" alt=""
data:image/s3,"s3://crabby-images/d8e10/d8e10565f5a9f59c59c3eec25d7188dac825346c" alt=""
data:image/s3,"s3://crabby-images/121ac/121ac802b6aae8fbdc09855b985ba95e39798b2b" alt=""
data:image/s3,"s3://crabby-images/4a6cf/4a6cfc2d6681cc07c3913b6debcb8669f8e1ba84" alt=""
可下载资源
关于作者
Kaizong Ye是拓端研究室(TRL)的研究员。在此对他对本文所作的贡献表示诚挚感谢,他在上海财经大学完成了统计学专业的硕士学位,专注人工智能领域。擅长Python.Matlab仿真、视觉处理、神经网络、数据分析。
本文借鉴了作者最近为《R语言数据分析挖掘必知必会 》课堂做的准备。
非常感谢您阅读本文,如需帮助请联系我们!
每日分享最新报告和数据资料至会员群
关于会员群
- 会员群主要以数据研究、报告分享、数据工具讨论为主;
- 加入后免费阅读、下载相关数据内容,并同步海内外优质数据文档;
- 老用户可九折续费。
- 提供报告PDF代找服务
非常感谢您阅读本文,如需帮助请联系我们!