data:image/s3,"s3://crabby-images/3a966/3a96689830833ba639fa59ac55982dec3882fae1" alt="App Inventor 字典功能簡單應用 App Inventor 字典功能簡單應用"
App Inventor 字典功能簡單應用
今天要來介紹,在 App Inventor 裡的字典功能,在使用上跟 List 差不多,也可以拿來讀取 Open Data 的資料,這次我會簡單的示範,如何讀取 YouBike 的站點名稱,那麼以下請跟著教學。
1. 開啟 App Inventor 並新增一個專案
元件只需要按鈕、標籤及網路元件就好
data:image/s3,"s3://crabby-images/c0a81/c0a81d46e9ce92658e8d8cc6030c14e7fe937d68" alt=""
切換到程式設計
我們先來新增一個變數,右邊放 “建立一個字典“。
“鍵” 的部份我們分別放 “apple” 和 “banana“
“值” 的部份我們分別放 “蘋果” 和 “香蕉”
data:image/s3,"s3://crabby-images/2b987/2b987988b6c3427c1b62c397fa0096bf727feccf" alt=""
然後當按鈕被點選後,將標籤文字設為 “取得字典…中對應於鍵…” 方塊。
這樣顯示時就會是 “蘋果“
data:image/s3,"s3://crabby-images/9c0c9/9c0c9a086762f27aaecc66738fc0249a905c3597" alt=""
底下的其它功能除了”鍵路徑“我還搞不太懂之外,其餘的都很簡單,可以試著 print 看看。
data:image/s3,"s3://crabby-images/067b4/067b4373c32a5c5c3079f5f7caa713e944ea94b5" alt=""
最後來看怎麼讀取 YouBike 資料
2. 先把 d 變數改為 “建立空的字典“
data:image/s3,"s3://crabby-images/f0a8f/f0a8f286943a3e264faeec85b2d99305dec7b6df" alt=""
當按鈕被點選要改成設定網址,並執行 GET 請求。
http://od-oas.kcg.gov.tw/api/service/Get/b4dd9c40-9027-4125-8666-06bef1756092
data:image/s3,"s3://crabby-images/b7c78/b7c78bd33367a1e0339258169023dbf0caff06be" alt=""
拖拉當網路元件取得文字方塊
裡面放設 d 變數為 “清單轉字典” 方塊,右邊放 JSON 解碼方塊。
data:image/s3,"s3://crabby-images/5564d/5564d5e5f01c9834a6e6508861808c8197b487f2" alt=""
因為回應內容是 json 格式,所以要先用解碼方塊,解碼後會變清單,所以再把清單轉成字典。
我們將資料拿去 Code Beautiful 分析,會發現我們要的站點名稱在 data 底下的,retVal 底下的 sna。
看到 retVal 的右邊有 [1006],[] -> 這個符號是清單的意思,所以等等在讀取底下的 sna 時,要用迴圈方塊,將裡面的 1006 筆站點名稱,顯示到我們的標籤。
data:image/s3,"s3://crabby-images/133be/133be8231ec821e1abe9defc3b9d9ae8db068532" alt=""
回到剛剛的方塊,於底下直接加入清單迴圈方塊,右邊則放 “取得字典…中對應於鍵…” 方塊,依序為 data 和 retVal。
data:image/s3,"s3://crabby-images/5f9ec/5f9ec1df39725045f8eb73a28ac52c2fb8739c5e" alt=""
裡面再用一次 “取得字典…中對應於鍵…” 方塊,將站點名稱加到文字標籤。
如此即可成功查詢站點資料!!
App 完整程式方塊
data:image/s3,"s3://crabby-images/9d536/9d53654286774d4e8897360fd6652f53450b7196" alt=""
App 專案程式檔案下載
App 範例執行畫面
如果覺得文章內容還不錯的話,麻煩請幫我點個讚!感謝
可以多點幾次喔~~
第一次點讚需使用 Google 或 Facebook 帳號註冊
data:image/s3,"s3://crabby-images/8a31b/8a31b2b2215ba34dc0de457b80469f03cbe4d931" alt="App Inventor 使用網頁檔案播放影音 App Inventor 使用網頁檔案播放影音"