csv 데이터를 IoT Analytics에 넣어 QuickSight로 시각화 (도쿄의 날씨)
11968 단어 IoTCoreawsIoTQuickSightIoTAnalytics
하고 싶은 일
IoT Analytics에서는 AWS IoT Core에서 얻은 데이터 외에 BatchPutMessage
를 사용하여 데이터를 캡처할 수 있습니다.
「실운용에서는 IoT Core로부터의 데이터를 해석하고 싶지만, 이미 있는 과거의 CSV데이터를 받아들여, 어떤 가시화나 해석이 가능한가를 시험해 보고 싶다」라고 할 때에 사용할 수 있습니다.
이번에는 기상청에서 도쿄의 날씨를 CSV로 얻고 QuickSight에서 시각화를 시도합니다.
htps : // / cs. 아 ws. 아마존. 코 m/이오타나 ly 치 cs/아 st/아피레후렌세/아피_바 tch푸t 메사게. HTML
원본 데이터 얻기
이번에는 기상청의 과거 기상 데이터 취득
htps //w w. 했다. j. . jp/gmd/리 sk/오 bsdl/
data:image/s3,"s3://crabby-images/d3f1c/d3f1c4a863ae9139a7c41b1a9f0ca9da986a8fc0" alt=""
도쿄에 체크를 넣다
data:image/s3,"s3://crabby-images/95620/95620ff38e2794b040fdc9bdd223a5e072a65a4c" alt=""
일별 평균 기온
data:image/s3,"s3://crabby-images/82ac8/82ac88a6b92179a6cd091ae0fb463e9fbea6dd3a" alt=""
30년분 획득
data:image/s3,"s3://crabby-images/89f0a/89f0a85a87ac257bc8d496fe6087e8de1c404d1d" alt=""
CSV 다운로드.
data:image/s3,"s3://crabby-images/d4285/d4285ff57e0dc729ab7c2d8c859a590afbaa1a16" alt=""
sjis처럼 보입니다.
data:image/s3,"s3://crabby-images/831fc/831fc29b8612cf84e571290d77789a5e38b27652" alt=""
IoT Analytics에 데이터 보내기
채널, 파이프라인, 데이터 스토어 만들기
이번에는 입력 데이터를 그대로 사용하므로 Pipeline에서는 특별히 처리하지 않습니다.
data:image/s3,"s3://crabby-images/610de/610de5a1ca7a7852d9a0ec992d9f2d51e9bd8286" alt=""
data:image/s3,"s3://crabby-images/68107/68107470b627ce2ca7e0e0fcc859533512272c16" alt=""
채널 ID : tokyo_temperature
data:image/s3,"s3://crabby-images/d628c/d628cf1c7773d5cc91157bd09c17ffee52b36269" alt=""
Create Channel을 누릅니다.
data:image/s3,"s3://crabby-images/c73ea/c73ea0f6dd7007d2c8509ca46b98c69058b94f9a" alt=""
채널에서 파이프라인을 만듭니다.
data:image/s3,"s3://crabby-images/a2208/a22087279f389f6eb9fa573f4f83115a2245f494" alt=""
data:image/s3,"s3://crabby-images/40a85/40a859cf1650bac74b11b2bb2cce637ea55e10f6" alt=""
Attribute를 설정합니다. 다음 활동은 그대로.
data:image/s3,"s3://crabby-images/35391/3539166c16b71ba2606b120aef51faf26d11cab1" alt=""
tokyo_temperature_store
라는 Data store name으로 만들고 Create.
데이터 Post
휴대용 PC에서 다음을 수행합니다.
import csv
import json
import datetime
import boto3
channelName = "tokyo_temperature"
with open('data.csv', encoding='shift_jis') as csvfile:
reader = csv.reader(csvfile)
messages = []
for row in reader:
if len(row) > 3:
format_str = '%Y/%m/%d'
try:
date = datetime.datetime.strptime(row[0], format_str)
temperature = row[1]
blob = {
"date": date.isoformat(),
"temperature": float(row[1])
}
obj = {
"messageId": date.strftime("%Y-%m-%d"),
"payload": json.dumps(blob).encode()
}
messages.append(obj)
except:
continue
client = boto3.client('iotanalytics', region_name='us-east-1')
i = 0
while i < len(messages):
client.batch_put_message(
channelName=channelName,
messages=messages[i:i+99]
)
i += 100
payload의 사이즈 상한이 있으므로, 100개씩 분할해 보내고 있습니다.
또한 region_name
는 적절하게 변경해야합니다.
data:image/s3,"s3://crabby-images/a342b/a342bae0ce4e61f77b712a12a680c61fb61a25c3" alt=""
IoT Analytics의 채널을 보면 메시지가 수신되었음을 알 수 있습니다.
데이터 시각화
data:image/s3,"s3://crabby-images/bf3ae/bf3ae666ac472c828dc6f97e4eab2e6d2348a36a" alt=""
Create a data set을 누릅니다.
data:image/s3,"s3://crabby-images/3c7ef/3c7efe0f96d58e9c983a64fd14d88783995ef7b1" alt=""
데이터스토어에서 데이터세트를 만듭니다. 이번에는 모든 데이터를 사용하여 데이터 세트를 만듭니다.
data:image/s3,"s3://crabby-images/3f87c/3f87c3885691b430b035d612afd7aaf549954d42" alt=""
ID는 tokyo_temperature_dataset
라는 이름으로 했습니다.
source는 방금 만든 것을 선택합니다.
data:image/s3,"s3://crabby-images/62176/621768ecc42a4789eed0131f6fadf7398bf05428" alt=""
모든 것을 얻기 때문에 쿼리는 그대로. 나머지 항목은 모두 기본값으로 유지되며 Data set을 만듭니다.
data:image/s3,"s3://crabby-images/53ade/53ade11074def1b9c1a2fd19af545ddec54c72e8" alt=""
원하는 데이터 세트를 선택하고 Action⇨Run now를 누릅니다.
data:image/s3,"s3://crabby-images/37af5/37af5183a7ef01766c052aa506b80b97fc018a19" alt=""
잠시 기다렸다가 Content를 누르면 생성된 데이터 세트를 미리 볼 수 있습니다.
데이터 시각화
작성한 데이터 세트를 QuickSight로 그대로 가져옵니다.
data:image/s3,"s3://crabby-images/e6861/e68613738cb888b0463d8df861991b9d45205c1e" alt=""
서비스에서 QuickSight를 선택합니다.
data:image/s3,"s3://crabby-images/eec97/eec97f838f5fd97d02dbfd9dcc69c3b4aa500677" alt=""
data:image/s3,"s3://crabby-images/f6490/f6490217c672a2356b3d7a3038b9b337ec866e76" alt=""
Standard를 선택.
data:image/s3,"s3://crabby-images/44c3e/44c3e27861484bc73b721db1ac2b598a4b828625" alt=""
모든 계정 이름, 메어드를 입력하고 AWS IoT Analytics를 확인한 후 Finish.
QuickSight에서 New Analysis ⇨ New data set ⇨ IoT Analytics를 선택합니다.
data:image/s3,"s3://crabby-images/cced1/cced1e6d0b645c9651fe2d763e2aa06b4d65d536" alt=""
작성한 데이터 소스 이름을 선택하고 Visualize.
data:image/s3,"s3://crabby-images/8ae44/8ae4493ed8edf09aaa065b3d4ce4715682ca5fa9" alt=""
date, temperature 를 선택하면 그래프가 표시되었습니다.
data:image/s3,"s3://crabby-images/71d75/71d758b923c66ec5e6d6d1f7344cb718939c75f4" alt=""
Visual types에서 막대 그래프를 선택하여 X axis에 date(YEAR)를 설정하고 Value에 Temperature(Average)를 설정하여 30년간의 연평균을 내 보았습니다. 큰 기온 변화는 없네요. .
Reference
이 문제에 관하여(csv 데이터를 IoT Analytics에 넣어 QuickSight로 시각화 (도쿄의 날씨)), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다
https://qiita.com/tatsuhiroiida/items/6467b22492f28ecc296c
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)
이번에는 기상청의 과거 기상 데이터 취득
htps //w w. 했다. j. . jp/gmd/리 sk/오 bsdl/
data:image/s3,"s3://crabby-images/d3f1c/d3f1c4a863ae9139a7c41b1a9f0ca9da986a8fc0" alt=""
도쿄에 체크를 넣다
data:image/s3,"s3://crabby-images/95620/95620ff38e2794b040fdc9bdd223a5e072a65a4c" alt=""
일별 평균 기온
data:image/s3,"s3://crabby-images/82ac8/82ac88a6b92179a6cd091ae0fb463e9fbea6dd3a" alt=""
30년분 획득
data:image/s3,"s3://crabby-images/89f0a/89f0a85a87ac257bc8d496fe6087e8de1c404d1d" alt=""
CSV 다운로드.
data:image/s3,"s3://crabby-images/d4285/d4285ff57e0dc729ab7c2d8c859a590afbaa1a16" alt=""
sjis처럼 보입니다.
data:image/s3,"s3://crabby-images/831fc/831fc29b8612cf84e571290d77789a5e38b27652" alt=""
IoT Analytics에 데이터 보내기
채널, 파이프라인, 데이터 스토어 만들기
이번에는 입력 데이터를 그대로 사용하므로 Pipeline에서는 특별히 처리하지 않습니다.
data:image/s3,"s3://crabby-images/610de/610de5a1ca7a7852d9a0ec992d9f2d51e9bd8286" alt=""
data:image/s3,"s3://crabby-images/68107/68107470b627ce2ca7e0e0fcc859533512272c16" alt=""
채널 ID : tokyo_temperature
data:image/s3,"s3://crabby-images/d628c/d628cf1c7773d5cc91157bd09c17ffee52b36269" alt=""
Create Channel을 누릅니다.
data:image/s3,"s3://crabby-images/c73ea/c73ea0f6dd7007d2c8509ca46b98c69058b94f9a" alt=""
채널에서 파이프라인을 만듭니다.
data:image/s3,"s3://crabby-images/a2208/a22087279f389f6eb9fa573f4f83115a2245f494" alt=""
data:image/s3,"s3://crabby-images/40a85/40a859cf1650bac74b11b2bb2cce637ea55e10f6" alt=""
Attribute를 설정합니다. 다음 활동은 그대로.
data:image/s3,"s3://crabby-images/35391/3539166c16b71ba2606b120aef51faf26d11cab1" alt=""
tokyo_temperature_store
라는 Data store name으로 만들고 Create.
데이터 Post
휴대용 PC에서 다음을 수행합니다.
import csv
import json
import datetime
import boto3
channelName = "tokyo_temperature"
with open('data.csv', encoding='shift_jis') as csvfile:
reader = csv.reader(csvfile)
messages = []
for row in reader:
if len(row) > 3:
format_str = '%Y/%m/%d'
try:
date = datetime.datetime.strptime(row[0], format_str)
temperature = row[1]
blob = {
"date": date.isoformat(),
"temperature": float(row[1])
}
obj = {
"messageId": date.strftime("%Y-%m-%d"),
"payload": json.dumps(blob).encode()
}
messages.append(obj)
except:
continue
client = boto3.client('iotanalytics', region_name='us-east-1')
i = 0
while i < len(messages):
client.batch_put_message(
channelName=channelName,
messages=messages[i:i+99]
)
i += 100
payload의 사이즈 상한이 있으므로, 100개씩 분할해 보내고 있습니다.
또한 region_name
는 적절하게 변경해야합니다.
data:image/s3,"s3://crabby-images/a342b/a342bae0ce4e61f77b712a12a680c61fb61a25c3" alt=""
IoT Analytics의 채널을 보면 메시지가 수신되었음을 알 수 있습니다.
데이터 시각화
data:image/s3,"s3://crabby-images/bf3ae/bf3ae666ac472c828dc6f97e4eab2e6d2348a36a" alt=""
Create a data set을 누릅니다.
data:image/s3,"s3://crabby-images/3c7ef/3c7efe0f96d58e9c983a64fd14d88783995ef7b1" alt=""
데이터스토어에서 데이터세트를 만듭니다. 이번에는 모든 데이터를 사용하여 데이터 세트를 만듭니다.
data:image/s3,"s3://crabby-images/3f87c/3f87c3885691b430b035d612afd7aaf549954d42" alt=""
ID는 tokyo_temperature_dataset
라는 이름으로 했습니다.
source는 방금 만든 것을 선택합니다.
data:image/s3,"s3://crabby-images/62176/621768ecc42a4789eed0131f6fadf7398bf05428" alt=""
모든 것을 얻기 때문에 쿼리는 그대로. 나머지 항목은 모두 기본값으로 유지되며 Data set을 만듭니다.
data:image/s3,"s3://crabby-images/53ade/53ade11074def1b9c1a2fd19af545ddec54c72e8" alt=""
원하는 데이터 세트를 선택하고 Action⇨Run now를 누릅니다.
data:image/s3,"s3://crabby-images/37af5/37af5183a7ef01766c052aa506b80b97fc018a19" alt=""
잠시 기다렸다가 Content를 누르면 생성된 데이터 세트를 미리 볼 수 있습니다.
데이터 시각화
작성한 데이터 세트를 QuickSight로 그대로 가져옵니다.
data:image/s3,"s3://crabby-images/e6861/e68613738cb888b0463d8df861991b9d45205c1e" alt=""
서비스에서 QuickSight를 선택합니다.
data:image/s3,"s3://crabby-images/eec97/eec97f838f5fd97d02dbfd9dcc69c3b4aa500677" alt=""
data:image/s3,"s3://crabby-images/f6490/f6490217c672a2356b3d7a3038b9b337ec866e76" alt=""
Standard를 선택.
data:image/s3,"s3://crabby-images/44c3e/44c3e27861484bc73b721db1ac2b598a4b828625" alt=""
모든 계정 이름, 메어드를 입력하고 AWS IoT Analytics를 확인한 후 Finish.
QuickSight에서 New Analysis ⇨ New data set ⇨ IoT Analytics를 선택합니다.
data:image/s3,"s3://crabby-images/cced1/cced1e6d0b645c9651fe2d763e2aa06b4d65d536" alt=""
작성한 데이터 소스 이름을 선택하고 Visualize.
data:image/s3,"s3://crabby-images/8ae44/8ae4493ed8edf09aaa065b3d4ce4715682ca5fa9" alt=""
date, temperature 를 선택하면 그래프가 표시되었습니다.
data:image/s3,"s3://crabby-images/71d75/71d758b923c66ec5e6d6d1f7344cb718939c75f4" alt=""
Visual types에서 막대 그래프를 선택하여 X axis에 date(YEAR)를 설정하고 Value에 Temperature(Average)를 설정하여 30년간의 연평균을 내 보았습니다. 큰 기온 변화는 없네요. .
Reference
이 문제에 관하여(csv 데이터를 IoT Analytics에 넣어 QuickSight로 시각화 (도쿄의 날씨)), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다
https://qiita.com/tatsuhiroiida/items/6467b22492f28ecc296c
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)
import csv
import json
import datetime
import boto3
channelName = "tokyo_temperature"
with open('data.csv', encoding='shift_jis') as csvfile:
reader = csv.reader(csvfile)
messages = []
for row in reader:
if len(row) > 3:
format_str = '%Y/%m/%d'
try:
date = datetime.datetime.strptime(row[0], format_str)
temperature = row[1]
blob = {
"date": date.isoformat(),
"temperature": float(row[1])
}
obj = {
"messageId": date.strftime("%Y-%m-%d"),
"payload": json.dumps(blob).encode()
}
messages.append(obj)
except:
continue
client = boto3.client('iotanalytics', region_name='us-east-1')
i = 0
while i < len(messages):
client.batch_put_message(
channelName=channelName,
messages=messages[i:i+99]
)
i += 100
data:image/s3,"s3://crabby-images/bf3ae/bf3ae666ac472c828dc6f97e4eab2e6d2348a36a" alt=""
Create a data set을 누릅니다.
data:image/s3,"s3://crabby-images/3c7ef/3c7efe0f96d58e9c983a64fd14d88783995ef7b1" alt=""
데이터스토어에서 데이터세트를 만듭니다. 이번에는 모든 데이터를 사용하여 데이터 세트를 만듭니다.
data:image/s3,"s3://crabby-images/3f87c/3f87c3885691b430b035d612afd7aaf549954d42" alt=""
ID는
tokyo_temperature_dataset
라는 이름으로 했습니다.source는 방금 만든 것을 선택합니다.
data:image/s3,"s3://crabby-images/62176/621768ecc42a4789eed0131f6fadf7398bf05428" alt=""
모든 것을 얻기 때문에 쿼리는 그대로. 나머지 항목은 모두 기본값으로 유지되며 Data set을 만듭니다.
data:image/s3,"s3://crabby-images/53ade/53ade11074def1b9c1a2fd19af545ddec54c72e8" alt=""
원하는 데이터 세트를 선택하고 Action⇨Run now를 누릅니다.
data:image/s3,"s3://crabby-images/37af5/37af5183a7ef01766c052aa506b80b97fc018a19" alt=""
잠시 기다렸다가 Content를 누르면 생성된 데이터 세트를 미리 볼 수 있습니다.
데이터 시각화
작성한 데이터 세트를 QuickSight로 그대로 가져옵니다.
data:image/s3,"s3://crabby-images/e6861/e68613738cb888b0463d8df861991b9d45205c1e" alt=""
서비스에서 QuickSight를 선택합니다.
data:image/s3,"s3://crabby-images/eec97/eec97f838f5fd97d02dbfd9dcc69c3b4aa500677" alt=""
data:image/s3,"s3://crabby-images/f6490/f6490217c672a2356b3d7a3038b9b337ec866e76" alt=""
Standard를 선택.
data:image/s3,"s3://crabby-images/44c3e/44c3e27861484bc73b721db1ac2b598a4b828625" alt=""
모든 계정 이름, 메어드를 입력하고 AWS IoT Analytics를 확인한 후 Finish.
QuickSight에서 New Analysis ⇨ New data set ⇨ IoT Analytics를 선택합니다.
data:image/s3,"s3://crabby-images/cced1/cced1e6d0b645c9651fe2d763e2aa06b4d65d536" alt=""
작성한 데이터 소스 이름을 선택하고 Visualize.
data:image/s3,"s3://crabby-images/8ae44/8ae4493ed8edf09aaa065b3d4ce4715682ca5fa9" alt=""
date, temperature 를 선택하면 그래프가 표시되었습니다.
data:image/s3,"s3://crabby-images/71d75/71d758b923c66ec5e6d6d1f7344cb718939c75f4" alt=""
Visual types에서 막대 그래프를 선택하여 X axis에 date(YEAR)를 설정하고 Value에 Temperature(Average)를 설정하여 30년간의 연평균을 내 보았습니다. 큰 기온 변화는 없네요. .
Reference
이 문제에 관하여(csv 데이터를 IoT Analytics에 넣어 QuickSight로 시각화 (도쿄의 날씨)), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다
https://qiita.com/tatsuhiroiida/items/6467b22492f28ecc296c
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)
Reference
이 문제에 관하여(csv 데이터를 IoT Analytics에 넣어 QuickSight로 시각화 (도쿄의 날씨)), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/tatsuhiroiida/items/6467b22492f28ecc296c텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)