R_Language 板


LINE

[問題類型]: 程式諮詢(我想用R 做某件事情,但是我不知道要怎麼用R 寫出來) [軟體熟悉度]: 使用者(已經有用R 做過不少作品) [問題敘述]: 我最近做了一隻Shiny程式,但它需要的運算耗時比較久, (而且在shinyapps.io上花的時間比我在本地長很多...) 好奇有沒有可能在UI裡面加一行提示(例如「運算中,請稍候」之類的), 而且只在結果還沒出來時才有那一行? 我知道也許長期目標是讓我的程式碼更有效率一點, 但目前我還想不到改寫的方式。 orz [程式範例]: ui <- fluidPage( # Other UI elements conditionalPanel(condition = "output.done == 'FALSE'", helpText("運算中,請稍候")) ) server <- function(input, output) { output$done <- reactive({"FALSE"}) # Complicated processes output$done <- reactive({"TRUE"}) outputOptions(output, "done", suspendWhenHidden = FALSE) } [關鍵字]: shiny, dynamic UI --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 118.167.58.15
※ 文章網址: https://webptt.com/m.aspx?n=bbs/R_Language/M.1503326582.A.2EC.html
1F:→ celestialgod: 關鍵字 showModal shiny 08/22 00:28
2F:→ celestialgod: 或是勇shinyBS,不過個人不推 08/22 00:29
3F:→ celestialgod: shinyBS::bsModal 一年前用有一些問題,不確定現在 08/22 00:31
4F:→ celestialgod: 有沒有改善,但是多數功能 shiny showModal就可以解 08/22 00:31
5F:→ celestialgod: 決 08/22 00:31
6F:→ clsmbstu: 感謝!再找時間來玩玩看~ 08/22 01:51
7F:推 cywhale: withProgress in shiny https://goo.gl/fA23za 08/22 09:15
8F:→ clsmbstu: 這個也好棒!大感謝! 08/22 10:37
※ 編輯: clsmbstu (140.112.25.106), 08/22/2017 11:13:43
9F:→ clsmbstu: 細讀之後發現我的狀況withProgress提供的幫助有限 08/22 15:35
10F:→ clsmbstu: 因為我最花時間的地方是leaflet::addPolygons而非迴圈 08/22 15:35
11F:→ clsmbstu: 我試過把地圖繪製的pipeline切開來並在中間放incProgess 08/22 15:37
12F:→ clsmbstu: 但詭異的是進度條跑滿了,圖還是要再等一陣子才會出來 08/22 15:38
13F:推 cywhale: 不是可以 withProgress(message=... { 08/23 01:05
14F:→ cywhale: ..(Your processes)..leaflet %<>% addPolygons() }) 08/23 01:06
我是參考你附的連結的寫法, (本來想把每個server outputs都包在一個withProgress一起讀進度,但邏輯好像不對) 以下是我的server function一部分的簡化(省去根據UI的一些條件判斷式): output$mapplot <- renderLeaflet({ # Define palettes pal <- colorNumeric("YlOrRd", merge_map()$Values) labs <- sprintf( "<strong>%s</strong><br>%g%%", merge_map()$CountyTown, merge_map()$Values ) %>% lapply(HTML) # Map plotting leaflet(merge_map()) %>% setView(121, 23.5, 7) %>% addTiles() %>% addPolygons(weight = 2, color = "white", dashArray = 3, fillColor = ~pal(Values), fillOpacity = 0.8, highlightOptions = highlightOptions( weight = 5, color = "#636363", bringToFront = TRUE ), label = labs, labelOptions = labelOptions( textsize = "15px", style = list("font-weight" = "normal") )) %>% addLegend(position = "bottomright", pal = pal, values = ~Values, opacity = 0.8, title = "Percentages", labFormat = labelFormat(suffix = "%")) }) 為了加進度條,變成: output$mapplot <- renderLeaflet({ withProgress( value = 0, message = "地圖繪製中", detail = "製作說明標籤" expr = { # Define palettes pal <- colorNumeric("YlOrRd", merge_map()$Values) labs <- sprintf( "<strong>%s</strong><br>%g%%", merge_map()$CountyTown, merge_map()$Values ) %>% lapply(HTML) incProgress(0.1, detail = "套疊地圖圖層") # Map plotting final_map <- leaflet(merge_map()) %>% setView(121, 23.5, 7) %>% addTiles() incProgress(0.2, detail = "繪製各區域資料") final_map <- addPolygons(final_map, weight = 2, color = "white", dashArray = 3, fillColor = ~pal(Values), fillOpacity = 0.8, highlightOptions = highlightOptions( weight = 5, color = "#636363", bringToFront = TRUE ), label = labs, labelOptions = labelOptions( textsize = "15px", style = list("font-weight" = "normal") )) incProgress(0.5, detail = "製作圖例") final_map <- addLegend(final_map, position = "bottomright", pal = pal, values = ~Values, opacity = 0.8, title = "Percentages", labFormat = labelFormat(suffix = "%")) incProgress(0.2, detail = "即將完成") } ) final_map }) 先不提每次的進度前進多少其實是我的主觀認定這件事, 要把原本的pipeline切開才能更新進度條也是有點麻煩。 最後更奇怪的是,進度條還是幾乎瞬間跑完,但地圖並沒有馬上出來... 我懷疑要把物件呈現上來本身也很花時間? 但是在這裡的倒數第二行"final_map"似乎不能包進withProgress裡面, 否則根本不會有地圖出來。 這樣提供的資訊夠嗎? ※ 編輯: clsmbstu (140.112.121.113), 08/23/2017 17:00:25
15F:推 cywhale: 跑比較多polygon在leaflet 最後這一步的確會慢一些.. 08/23 22:04
16F:→ cywhale: 不過如果用leafletProxy放不需要更新的部分,只更新新的 08/23 22:08
17F:→ cywhale: addpolygon部分 不知道對最後這一步顯示速度有無幫助.. 08/23 22:09
18F:→ clsmbstu: 感謝!我也有查到leafletProxy,但我是主觀猜測應該幫助 08/23 22:30
19F:→ clsmbstu: 不大,畢竟我每次更換輸入就是要重畫超過350個polygons 08/23 22:31
20F:→ clsmbstu: 而前面只是做到addTiles而已 QQ 08/23 22:32
21F:推 locka: 請問clsmbstu大大是在一個addPolygons()裡超過350個多邊形( 08/23 23:14
22F:→ locka: 例如全台鄉鎮)還是addPolygons()執行350次啊?? 08/23 23:14
23F:→ clsmbstu: 是前者喔 我就是在畫全臺鄉鎮 XD 08/23 23:40







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:BabyMother站內搜尋

TOP