-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathget_data.R
98 lines (87 loc) · 4.06 KB
/
get_data.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
library(grid)
library(stringr)
library(RJSONIO)
library(Rbitcoin)
library(plyr)
library(igraph)
library(jsonlite)
library(httr)
library(anytime)
library(ggplot2)
library(ggpmisc)
setwd("~/r-studio-workspace/bitcoin/dashboard")
today <- Sys.Date()
dataset <- NULL
actual_size <- as.numeric(fromJSON('https://chain.api.btc.com/v3/block/latest')$data$height)
start_size <- actual_size-(30*144)-1 # 144 blocks around 1 day
stop_size <- actual_size
try(load(file="./data/block_size_btc.com.RData"))
for(i in start_size:stop_size) {
if (!(i %in% dataset$height)){
tryCatch({
print(i)
block <- fromJSON(paste0('https://chain.api.btc.com/v3/block/',i))
row <- NULL
row$height <- i
row$hash <- block$data$hash
row$size <- block$data$size
row$n_tx <- block$data$tx_count
row$time <- block$data$timestamp
row$pool <- block$data$extras[["pool_name"]]
row$when <- as.POSIXct(row$time, origin="1970-1-1")
row$size_mb <- row$size/1024/1024
row$delta <- 0
dataset <- rbind(dataset, as.data.frame(row))
dataset$delta <- c(0,tail(dataset$when, -1) - head(dataset$when, -1))
save(dataset, file="./data/block_size_btc.com.RData")
}, error = function(e) {
print("error")
})
Sys.sleep(2)
}
}
mempool <- read.csv("https://api.blockchair.com/bitcoin/mempool/transactions?fields=block_id,id,hash,time,is_coinbase,input_count,output_count,cdd_total,input_total,input_total_usd,output_total,output_total_usd,fee,fee_usd,fee_per_kb,fee_per_kb_usd,fee_per_kwu,fee_per_kwu_usd,has_witness,size,weight,lock_time&export=csv")
save(mempool, file="./data/mempool.RData")
options(scipen = 999)
now <- as.numeric(as.POSIXct(Sys.time()))
today <- round(now*1000)
yesterday <- round(as.numeric(now-1*24*3600)*1000)
lastWeek <- round(as.numeric(now-7*24*3600)*1000)
lastMonth <- round(as.numeric(now-30*24*3600)*1000)
test <- fromJSON(paste0("https://graphs2.coinmarketcap.com/currencies/bitcoin/",yesterday,"/",today,"/"))
price_usd_day <- as.data.frame(test$price_usd)
if (nrow(price_usd_day) < 5) price_usd_day <- as.data.frame(matrix(unlist(test$price_usd), ncol = 2, byrow = TRUE))
names(price_usd_day) <- c("timestamp","value")
price_usd_day$timestamp <- anytime(price_usd_day$timestamp/1000)
save(price_usd_day, file="./data/price_usd_day.RData")
test2 <- fromJSON(paste0("https://graphs2.coinmarketcap.com/currencies/bitcoin/",lastWeek,"/",today,"/"))
price_usd_week <- as.data.frame(test2$price_usd)
if (nrow(price_usd_week) < 5) price_usd_week <- as.data.frame(matrix(unlist(test2$price_usd), ncol = 2, byrow = TRUE))
names(price_usd_week) <- c("timestamp","value")
price_usd_week$timestamp <- anytime(price_usd_week$timestamp/1000)
save(price_usd_week, file="./data/price_usd_week.RData")
test3 <- fromJSON(paste0("https://graphs2.coinmarketcap.com/currencies/bitcoin/",lastMonth,"/",today,"/"))
price_usd_month <- as.data.frame(test3$price_usd)
if (nrow(price_usd_month) < 5) price_usd_month <- as.data.frame(matrix(unlist(test3$price_usd), ncol = 2, byrow = TRUE))
names(price_usd_month) <- c("timestamp","value")
price_usd_month$timestamp <- anytime(price_usd_month$timestamp/1000)
save(price_usd_month, file="./data/price_usd_month.RData")
p1 <- ggplot(price_usd_month, aes(x=timestamp, y=value)) +
stat_smooth(
color = "#FC4E07", fill = "#FC4E07",
method = "loess"
) +
geom_line() +
stat_peaks(colour = "red", span = 25) +
stat_peaks(geom = "text", colour = "red", span = 25,
vjust = -0.5, x.label.fmt = "%d %H:%M") +
stat_valleys(colour = "blue", span = 25) +
stat_valleys(geom = "text", colour = "blue", angle = 45, span = 25,
vjust = 1.5, hjust = 1, x.label.fmt = "%H:%M") +
annotate("text", x = max(price_usd_day$timestamp), y = Inf, label = paste0(as.Date(anytime(today/1000)), " - valeriovaccaro.it"),
hjust=1.1, vjust=1.1, col="black", cex=4,
fontface = "bold", alpha = 0.3) +
ggtitle("BTC price value - 1 month") +
labs(y="Value [USD]", x="Date") +
theme(axis.text.x = element_text(angle=45, hjust=1))
ggsave(filename="/var/www/html/vale/btc_value.png", plot=p1)