-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCode.txt
46 lines (42 loc) · 1.95 KB
/
Code.txt
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
#Adjust R for it to be able to handle the huge csv files being written
Sys.setenv(R_ZIPCMD= "C:/Rtools/bin/zip")
#Upload the inpatientcharges data and a list of U.S. individual states
data<-read.csv(file.choose())
list<-read.csv(file.choose())
#Load packages
library(dplyr)
library(openxlsx)
require(openxlsx)
#Define the loop variables (this report will have two levels state and city , hence two loop variables)
i <- 1
j <- 1
#convert the Numeric column of AVerage Total Payment to as.numeric to enable summarising
data$Average.Total.Payments<-as.numeric(data$Average.Total.Payments)
#The first loop will filter the data according to state, then define the maximum iterations for the second loop
while (j < 53) {
{
x<-list[j,1]
data.frame(x)
xclaims <- data[which(data$Provider.State %in% x ),]
a <- data.frame(unique(xclaims$Provider.City))
b <- nrow(a)+1
c <- list()
#The second loop will further drill down to the specific cities and hospitals in those cities
while (i < b){
{
d<-a[i,1]
data.frame(d)
Provider.Data<-xclaims[which(xclaims$Provider.City %in% d),]
Provider.Hospital.State.analysis<-group_by(Provider.Data,DRG.Definition,Provider.Name)%>%summarise( x = (Average.Total.Payments), y = (Average.Medicare.Payments),z= (x-y))%>%arrange(z)
colnames(Provider.Hospital.State.analysis)<-c("Disease.Profile","Provider.Name","Mean.Total.Payments","Mean.Medicare.Payments","Variance")
c[[paste0(d,".REPORT")]] <- Provider.Hospital.State.analysis
}
i<-i+1
}
#Finally the below code is used for writing the various data.frames into excel,to loop over the reports I have included the i variable
hs <- createStyle(textDecoration = "BOLD", fontColour = "#FFFFFF", fontSize=12,fontName="Arial Narrow", fgFill = "#4F80BD")
write.xlsx(c,asTable = TRUE,colWidths = "auto",borderColour ="#RRRRRR" ,headerStyle = hs,file = paste0("PROVIDER REPORT FOR ",list[j,1],".xlsx"))
}
j<-j+1
i<-1
}