После использования функции заказа, как я могу получить доступ к элементам, хранящимся в списке? - PullRequest
0 голосов
/ 15 октября 2019

Когда функция order используется, она создает список? В конце концов, передается вектор или фрейм данных нисходящей или восходящей структуры. В качестве альтернативы мне пришлось бы создать пустой список, выполнить цикл for для каждого элемента и передать их по отдельности в список, чтобы создать список. Я не думаю, что этот последний подход необходим. Как тогда получить определенный элемент из списка, созданного функцией сортировки?

В коде, когда вызывается функция, число передается в качестве аргумента для ранжирования больницы. Этот номер рейтинга затем используется для выявления элемента списка, созданного функцией заказа, используемой при, скажем, сердечной недостаточности, но он не работает должным образом. orderStateNum <- orderState$Hospital.30.Day.Death..Mortality..Rates.from.Heart.Failure[[num]]

best("AK","heart failure", 5)

best <- function(state, outcome, num) {
  #read file function

  #Reads the csv file
  dataTable  <- read.csv("outcome.csv", header = TRUE, stringsAsFactors = FALSE)

  #Passes the state argument to the choice variable
  choice <- state
  #selects all rows which match the state that was selected
  stateOfChoice <- dataTable[dataTable$State == "AK",]





  #Makes sure that only three of outcomes found in the csv file are selected
  if(outcome != "heart failure" && outcome != "heart attack" && outcome != "pneumonia"){
    print("wrong condition, try again")
    main()
  }

  #using the selected rows from above, return the minimum value of rate from heart attack and then use this selected row to find the hospital name
  else if (outcome == "heart attack"){



    heart_attack <- stateOfChoice[which.min(stateOfChoice$Hospital.30.Day.Death..Mortality..Rates.from.Heart.Attack),]
    heart_attack
    hospital <- heart_attack$Hospital.Name
    hospital
    return(hospital)
  }

  #Similar as above, but instead with heart failure
  else if (outcome == "heart failure"){

    orderState <- stateOfChoice[order(as.integer(stateOfChoice$Hospital.30.Day.Death..Mortality..Rates.from.Heart.Failure),decreasing = FALSE),]
    orderState
    orderStateNum <- orderState$Hospital.30.Day.Death..Mortality..Rates.from.Heart.Failure[[num]]
    orderStateNum  
    ##heart_failure <- stateOfChoice[which.min(stateOfChoice$Hospital.30.Day.Death..Mortality..Rates.from.Heart.Failure),]
    hospital <- heart_failure$Hospital.Name
    return(hospital)
  }

  #Similar as above, but instead with pneumonia
  else if (outcome == "pneumonia"){


    pneumonia <- stateOfChoice[which.min(stateOfChoice$Hospital.30.Day.Death..Mortality..Rates.from.Pneumonia),]
    pneumonia
    hospital <- pneumonia$Hospital.Name
    return(hospital)
  }

}

Данные: Нажмите

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...