์๋ ํ์ธ์. ๋ถ๋์ฐ ์ฒญ์ฝ ์ ๋ณด๋ OPEN API ํ์ฉํ์ฌ ์ ๋ณด๋ฅผ ๋ฐ์ ์ฌ ์ ์๋๊ฑฐ ์์๋์? ํด๋น ์ฌ์ดํธ์์๋ ๊ณต๊ณต๋ฐ์ดํฐ๋ ๋ค ๊ฐ์ ธ์ฌ ์ ์๋๋ฐ์. ๋งค๋ฒ ํฐ์คํ ๋ฆฌ์ ์ฒญ์ฝ ์ ๋ณด๋ฅผ ์๋์ผ๋ก ์ฌ๋ฆฌ๋๋ผ ๊ณ ๋ฏผํ๋๋ฐ, ๋ง์นจ ํด๋น ์ฌ์ดํธ๊ฐ ์์ด ์๋ํ ํ๋๋ก ๊ตฌํํ์๋ต๋๋ค.
์ ๋ณด
- ๊ฐ๋ฐ ํด : Google apps script
- ์ฌ์ฉ API : ๊ณต๊ณต๋ฐ์ดํฐ ํฌํธ OPEN API , ๋ค์ ์ด๋ฏธ์ง ๊ฒ์ OPEN API , ์ ํ๋ธ ๊ฒ์ OPEN API , ํฐ์คํ ๋ฆฌ OPEN API
๋ค๋ฅธ ํ๋ก๊ทธ๋จ ์ค์นํ๋ ๊ฒ ๋ณด๋ค ๊ตฌ๊ธ ์ฑ์คํฌ๋ฆฝํธ๋ ์ค์น ์์ด ๊ฐ๋ฐ ํ ์ ์์ด ์ ๊ฐ ์ฆ๊ฒจ ์ฌ์ฉํฉ๋๋ค. ํ์ด์ฌ, nodejs ๋ฑ๋ ์ข์ง๋ง ํน์ ๋๋ฌด ๋ถ๋ด์ค๋ฌ์ธ ๊ฒฝ์ฐ google app script๋ฅผ ํ์ฉํด๋ณด์ธ์
๊ฐ๋ฐ ๋ฐฉ๋ฒ
1. data.go.kr ์ ์ํ์ฌ ๋ก๊ทธ์ธ ํ๊ธฐ
2. ํ๊ตญ๋ถ๋์ฐ์_์ฒญ์ฝํ ๋ถ์์ ๋ณด ์กฐํ ์๋น์ค ๊ฒ์ํ์ฌ ํ์ฉ ์ ์ฒญ
๊ฐ๋ฐ ๊ณ์ ๋ ํ๋ฃจ 10,000๊ฑด ๋ฌด๋ฃ๋ก ์ฌ์ฉ์ด ๊ฐ๋ฅํ๊ธฐ ๋๋ฌธ์ ํฐ์คํ ๋ฆฌ์ ๋ฑ๋กํ๋ ๊ฑด์๋ก๋ ๋ฌด๋ฆฌ๊ฐ ์์ด ์ ๋ ์ด์๊ณ์ ์ ์ฒญ์ ๋ณ๋๋ก ํ์ง ์์์ต๋๋ค. ์๋ ์น์ธ์ด ๋๋ฏ๋ก ๋ณ๋ ์ ์ฐจ ์์ด ๋ฐ๋ก ์ฌ์ฉ์ด ๊ฐ๋ฅํฉ๋๋ค.
3. ์๋น์ค ์ ๋ณด๊ฐ๋ฉด ์ธ์ฆํค๊ฐ ์์ต๋๋ค. API๋ก ์ ๋ณด ์์ฒญ ์ ์ฒญ์ฝ ์ ๋ณด๋ฅผ ๋ฐ์ ์ ์์ต๋๋ค.
4. ์ฌ์ฉ ๊ฐ๋ฅํ API ๋ชฉ๋ก์ ๋๋ค. ์ ๋ ์ฐ์ APT ์์ธ๊ถ๋ง ๋ถ์์ ๋ณด๋ฅผ ๋ฐ์์ค๋๋ก ํ์์ต๋๋ค. ๋ค์์ ์คํผ์คํ ๋ ํด์ ์๋ ๋ฐํ ํด์ผ๊ฒ ์ต๋๋ค.
5. ์๋ ์์ค์ฝ๋๋ฅผ ๊ตฌ๊ธ app script์ ๋ฃ์ด๋ณด์ธ์ json ํ์ธํด๋ณด์ธ์
function getLHInfo()
{
var serviceKey = "์ธ์ฆํค๊ฐ";//๋ฐ๊ธ๋ฐ์ key๊ฐ
var returnType= "JSON"; //๋ฐ์ดํฐ ํํ
var cond_area = "์์ธ"; //์ฒญ์ฝ์ ๋ณด์ง์ญ
var eDay = "xxxx-xx-xx"; //๋๋ ์ง
var sDay = "xxxx-xx-xx"; //์์๋ ์ง
var url = "https://api.odcloud.kr/api/ApplyhomeInfoDetailSvc/v1/getAPTLttotPblancDetail?page=1&perPage=10&returnType="+ returnType + "&cond[SUBSCRPT_AREA_CODE_NM::EQ]="+ cond_area + "&cond[RCRIT_PBLANC_DE::LTE]="+ eDay + "&cond[RCRIT_PBLANC_DE::GTE]="+ sDay + "&serviceKey=" + serviceKey;
var response = UrlFetchApp.fetch(url,
{
method: "GET",
headers:{
"contentType": "application/json"
}
});
var json = response.getContentText();
var data = JSON.parse(json);
console.log("๋ฐ์ดํฐ ํ์ธ : " , data);
}
6. ์ด๋ฏธ์ง๋ ์ ํ๋ธ ๋งํฌ๊ฐ ํ์ํ ๊ฒฝ์ฐ
์๋ ๋ค์ ๊ฒ์ ๋ฐ ์ ํ๋ธ ๊ฒ์ ๊ธฐ๋ฅ์ ํ์ฉํ์ฌ ํ์ํ ์์๊ณผ ์ด๋ฏธ์ง๋ฅผ ๊ฐ์ ธ์ต๋๋ค.
[์นด์นด์ค๋ทฐ] ๋ณด๋ ์๋ ๋ฐํ 1๋จ๊ณ. ๊ตฌ๊ธ ์ฑ ์คํฌ๋ฆฝํธ๋ก ๋ค์ด๋ฒ ๋ด์ค, ๋ค์ ์น๋ฌธ์ ๊ฐ์ ธ์ค๊ธฐ(OPEN AP
์นด์นด์ค๋ทฐ ์๋๋ฐํ์ ํ๋ ค๋ค ๋ณด๋ ์ด๋ค ์ฝํ ์ธ ๋ฅผ ๊ฐ์ ธ์์ผ ํ ์ง ๊ณ ๋ฏผํ๋ค. ๊ธฐ์กด๊น์ง ์๋์ผ๋ก ํ๋ ๋ณด๋ ๋ฐํ์ ํธ๋ฆฌํ๊ฒ ํ๊ณ ์ถ์๋ค. ๊ทธ๋์ ์๋ ๋ฐํ์ ์๊ฐํด๋ณด๊ธฐ๋ก ํ์๋ค. 1. ์ฝํ ์ธ : ๋ค
odaily.tistory.com
[์นด์นด์ค๋ทฐ] ๋ณด๋ ์๋ ๋ฐํ 4๋จ๊ณ, ์ ํ๋ธ(Youtube) API ์ฌ์ฉํ์ฌ ๊ฒ์ ํค์๋๋ก ์์ ๊ฐ์ ธ์ค๊ธฐ , googl
์นด์นด์ค๋ทฐ ์๋ ๋ฐํ์ ๊ณ ๋ฏผํ๋ฉด์ ๋ค์ ๋ด์ค N๊ฐ, ๋ค์ด๋ฒ ๋ด์ค N๊ฐ, ํฐ์คํ ๋ฆฌ N๊ฐ, ๋ค์ด๋ฒ ๋ธ๋ก๊ทธ N๊ฐ, ์ ํ๋ธ N๊ฐ ์ด๋ ๊ฒ ์ค์ ํ์ฌ ๋ฐํ ๊ฐ๋ฅํ๋๋ก ์๊ฐํ์๋ค. ๋งค์ผ 00:00๋ฉด ์๋์ผ๋ก playlist ๋ณด๋
odaily.tistory.com
7. ํฐ์คํ ๋ฆฌ ์๋๋ฐํ
[google app script] ํฐ์คํ ๋ฆฌ OPEN API๋ก ๊ฒ์๊ธ ๋ฐํ ๋ฐฉ๋ฒ
์ง๋๋ฒ์๋ wiki ๋ฐฑ๊ณผ api๋ก ๋ฐ์ดํฐ ๋ถ๋ฌ์ค๋ ๊ฒ์ ์๋ํํ์๋๋ฐ์. ์ด๋ฒ์๋ ํฐ์คํ ๋ฆฌ ๊ฒ์๊ธ์ ์๋์ผ๋ก ๋ฐํํด๋ณด๋ ค๊ณ API๋ฅผ ํตํด ๊ฒ์๊ธ ์์ฑํ๋ ๋ฐฉ๋ฒ์ ์ ๋ฌํฉ๋๋ค. ์ฐ์ ์ง๋๋ฒ ์๋๋ฐํ
odaily.tistory.com
8. ์๋๋ฐํํ ์ฒญ์ฝ์ฝํ ์ธ
์์ธ ์ฒ์์ญ ๋ชจ์์๊ฐ ํธ๋ ๋ทฐ ๋ถ์ ์ ๋ณด, ํ๋ฆผ๊ฑด์ค(์ฃผ), ๊ณต๊ธ๋ฉด์ 140
์ค๋์ ์ํํธ ๋ถ์์ ๋ณด ์ฒ์์ญ ๋ชจ์์๊ฐ ํธ๋ ๋ทฐ ๋ด์ฉ ๊ณต์ ๋๋ฆฝ๋๋ค. [์ฃผํ ์ ๋ณด] ์ฌ์ง ์ถ์ฒ : ํฐ์คํ ๋ฆฌ http://odaily.tistory.com/593 ๊ฑด์ค์ฌ : ํ๋ฆผ๊ฑด์ค(์ฃผ) ์ฌ์ดํธ๋งํฌ : http://์ฒ์์ญ๋ชจ์์๊ฐํธ๋ ๋ทฐ.c
odaily.tistory.com
๋จ์ ์ ์ธ๋ค์ผ์ ์ง์ ํ ์ ์์ต๋๋ค. ๊ทธ๋ฅ ๊ฐ๋ ๋ค๋ ค์ ์ธ๋ค์ผ๋ง ๋ฑ๋ก ํด์ผ ํ ๊ฒ ๊ฐ์์. ์์ ๊ฐ์ด HTML์ ๋ง๋ค์ด์ ์ ๋๋ ๊ฒ์ด ํ์ธ์ด ๋๋ฉด apps script์ ํธ๋ฆฌ๊ฑฐ ๊ธฐ๋ฅ์ ํ์ฉํ์ฌ ํ๋ฃจ์ 1๋ฒ ๋์ํ๋๋ก ์ค์ ํด์ฃผ์ธ์!
์ด์์ผ๋ก ์ฒญ์ฝ์ ๋ณด OPEN API ํ์ฉํ์ฌ ํฐ์คํ ๋ฆฌ ๊ฒ์๊ธ ๋ฑ๋กํ๋ ๋ฐฉ๋ฒ์ด์์ต๋๋ค.
๋๊ธ