-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathchi_foia.R
120 lines (104 loc) · 3.45 KB
/
chi_foia.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
library(RCurl)
library(xts)
foia_logs <- c(
buildings='ucsz-xe6d',
revenue='zrv6-shhf',
three11='j2p9-gdf5',
transportation='u9qt-tv7d',
law='44bx-ncpi',
aviation='jbth-h7cm',
ethics='fhb6-wwuu',
environment='s7ek-ru5b',
police='wjkc-agnm',
fire='un3c-ixb7',
oemc='8pxc-mzcv',
health='4h87-zdcp',
compliance='pv55-neb6',
#finance='7avf-ek45', # Something's wrong with the SODA API
procurement='bcyv-67qk',
mayor='srzw-dcvg',
water='cxfr-dd4a',
streets='zpd8-zq4w',
admin.hearing='t58s-ja5s',
human.resources='7zkx-3pp7',
budget='c323-fb2i',
doit='4nng-j9hd',
fleet='ten5-q8vs',
human.relations='52q7-yupi',
special.events='kpzx-wx3r',
clerk='72qm-3bwf',
cultural='npw8-6cq9',
comm.dev='rpya-q7ut',
planning='5ztz-espx',
animal='b989-387c',
police.board='9pd8-s9t4',
business.affairs='ybhx-inqb',
ipra='gzxp-vdqf',
family='yfhi-bd8g',
license.commission='4nkr-n688',
disability='fazv-a8mb',
chicago.library='n379-5uzu',
cultural='ikdf-ernx',
treasurer='8gyi-fawp',
zoning='2nra-kpzu',
graphics='57s6-wkzs',
fleet.facilities='nd4p-ckx9'
)
date_received = c(
police='date_recieved',
oemc='received_date',
fleet='date_requested')
full_log <- data.frame(year_month=NA)
for (i in 1:length(foia_logs)) {
log_id <- foia_logs[i]
log_name <- names(log_id)
if (log_name %in% names(date_received)) {
request_date <- date_received[log_name]
}
else {
request_date <- 'date_received'
}
log_url <- paste(
'https://data.cityofchicago.org/resource/',
log_id,
'.csv?$select=date_trunc_ym(',
request_date,
')%20as%20year_month,COUNT(*)&$group=year_month&$order=year_month',
sep='')
log.csv <- RCurl::getURLContent(log_url)
log <- read.csv(textConnection(log.csv))
names(log) <- c("year_month", log_name)
full_log <- merge(full_log, log, by="year_month", all=TRUE)
}
full_log$year_month <- as.Date(full_log$year_month, '%m/%d/%Y %I:%M:%S %p')
write.csv(full_log[order(full_log$year_month),],
file="foia_logs.csv", row.names=FALSE)
# Quarter 1 of 2011 was the first Quarter where we had data for
# all the FOIA logs
good_log <- full_log[(full_log$year_month >= "2011-01-01"
& full_log$year_month < "2015-01-01"
& !is.na(full_log$year)),]
good_log <- good_log[, colSums(is.na(good_log)) != nrow(good_log)]
funky_datasets <- c("police", "admin.hearing", "health")
good_log$total <- rowSums(good_log[, !(names(good_log)
%in%
c("year_month",
funky_datasets))],
na.rm=TRUE)
ordered_depts <- names(sort(colSums(good_log[, -1],
na.rm=TRUE)))
log_xts <- xts::xts(good_log[, -1],
good_log$year_month)
for (dept in ordered_depts) {
plot(log_xts[, dept], main=dept)
Sys.sleep(2)
}
png("total.png", width=480, height=240)
plot(xts::apply.quarterly(log_xts$total, sum), main="Total")
dev.off()
png("buildings.png", width=480, height=240)
plot(xts::apply.quarterly(log_xts$building, sum), main="Buildings")
dev.off()
png("not_buildings.png", width=480, height=240)
plot(xts::apply.quarterly(log_xts$total, sum) - xts::apply.quarterly(log_xts$building, sum), main="Total - Buildings")
dev.off()