Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

C# - 버스 노선 및 위치 정보 조회 API 사용을 위한 기초 라이브러리

자, 지난 글도 썼으니,

공공 데이터 포털에서 버스 노선 및 위치 정보 조회 API 사용법
; https://www.sysnet.pe.kr/2/0/12779

간단한 코딩도 좀 해야겠지요. ^^

물론, 바닥부터 라이브러리를 만들어도 되겠지만, 어느 친절하신 분이 이미 위의 내용 정도에 해당하는 것을 Nuget 패키지로 올렸으니,

KoreaBusInfo
; https://www.nuget.org/packages/KoreaBusInfo/

간단하게 다음과 같이 패키지 참조하고,

Install-Package KoreaBusInfo

이렇게 사용할 수 있습니다.

using System;
using System.Collections.Generic;
using System.IO;
using KoreaBusInfo.Seoul;

namespace ConsoleApp1
{
    // Install-Package KoreaBusInfo
    class Program
    {
        // 서울 103번 버스에 대한 정류장 및 운행 정보 조회
        static void Main(string[] args)
        {
            string busNumber = "103";
            string key = "...[인증키(Encoding)]...";

            BusInfo sbi = new BusInfo(key);

            BusRoute busRoute = sbi.GetBusRoute(busNumber);
            Console.WriteLine($"Bus: {busNumber}, RouteID == {busRoute.busRouteId}");

            List<BusStation> stations = sbi.GetBusStations(busRoute);
            Console.WriteLine($"정류장(총: {stations.Count}개):");
            foreach (BusStation station in stations)
            {
                Console.WriteLine($"\t{station.stationNm}({station.station})");
            }

            List<BusPosition> positions = sbi.GetBusPositions(busRoute, stations);
            Console.WriteLine($"운행 중인 버스(총: {positions.Count}개):");
            foreach (BusPosition position in positions)
            {
                BusStation lastStation = stations.Find((elem) => elem.station == position.lastStnId);
                Console.WriteLine($"\t'lastStation: {lastStation.stationNm}', 현재 위치 ({position.posX}, {position.posY})");
            }
        }
    }
}

/* 출력 결과
Bus: 103, RouteID == 100100008
정류장(총: 71개):
        삼화상운(110000391)
        월계2교.참누리아파트(107000095)
        광운초교앞(107000097)
        장위래미안아파트(107000522)
        꿈의숲아이파크아파트(107000130)
        장곡초교사거리(107000132)
        장곡초교(107000197)
        국민은행장위동지점(107000186)
        장위1동치안센터(107000184)
        장위1동주민센터(107000182)
        장위동고개(107000180)
        장위동입구(107000516)
        창문여고앞(108000101)
        숭곡초등학교입구(108000102)
        월곡뉴타운(107000001)
        길음뉴타운(107000003)
        미아리고개.미아리예술극장(107000005)
        돈암사거리.성신여대입구(107000007)
        삼선동주민센터(107000085)
        성북구청.성북경찰서(107000087)
        보문역(107000089)
        보문동성당(107000091)
        보문동주민센터(107000093)
        신설동로터리(100000147)
        동묘앞(100000367)
        동대문(흥인지문)(100000365)
        종로6가.동대문종합시장(100000397)
        종로5가.광장시장(100000395)
        종로4가.종묘(100000393)
        종로3가.탑골공원(100000391)
        종로2가(100000389)
        종로1가(100000387)
        광화문(100000385)
        서울역사박물관.경희궁앞(100000379)
        경찰청.동북아역사재단(112000399)
        서울역버스환승센터(101000006)
        숭례문(101000027)
        남대문시장앞.이회영활동터(101000114)
        롯데영프라자(101000043)
        우리은행종로지점(101000040)
        종로2가(100000388)
        종로3가.탑골공원(100000390)
        종로4가.종묘(100000392)
        종로5가.광장시장(100000394)
        종로6가.동대문종합시장(100000396)
        동대문역.흥인지문(100000398)
        동묘앞(100000366)
        신설동역1번출구(105000552)
        보문동주민센터(107000094)
        보문동성당(107000092)
        보문역(107000090)
        성북구청.성북경찰서(107000088)
        삼선동주민센터(107000086)
        돈암사거리.성신여대입구(107000008)
        미아리고개.미아리예술극장(107000006)
        길음뉴타운(107000004)
        월곡뉴타운(107000002)
        숭곡초교입구(107000011)
        창문여고(107000012)
        장위동고개(107000179)
        장위1동주민센터(107000181)
        장위1동치안센터(107000183)
        국민은행장위동지점(107000185)
        장곡초교(107000198)
        장곡초교사거리(107000131)
        꿈의숲아이파크아파트(107000129)
        장위래미안아파트(107000521)
        광운초교(107000098)
        월계2교(107000096)
        월계주공1단지아파트앞(110000656)
        삼화상운(110000391)
운행 중인 버스(총: 21개):
        'lastStation: 꿈의숲아이파크아파트', 현재 위치 (204525.3, 457636.47)
        'lastStation: 월곡뉴타운', 현재 위치 (202233.31, 456096.72)
        'lastStation: 보문역', 현재 위치 (201670.97, 454037.62)
        'lastStation: 동대문(흥인지문)', 현재 위치 (201064.02, 452495.2)
        'lastStation: 종로4가.종묘', 현재 위치 (199348.3, 452335.88)
        'lastStation: 서울역사박물관.경희궁앞', 현재 위치 (197193.97, 451992.4)
        'lastStation: 서울역버스환승센터', 현재 위치 (197606.02, 450669.7)
        'lastStation: 우리은행종로지점', 현재 위치 (198492.05, 452003.2)
        'lastStation: 종로5가.광장시장', 현재 위치 (200127.38, 452374.38)
        'lastStation: 보문동주민센터', 현재 위치 (201915.1, 453511.66)
        'lastStation: 돈암사거리.성신여대입구', 현재 위치 (201746.34, 455056.88)
        'lastStation: 창문여고', 현재 위치 (203532.77, 457174.44)
        'lastStation: 장위래미안아파트', 현재 위치 (204694.03, 457735.78)
        'lastStation: 삼화상운', 현재 위치 (204438.42, 458648.3)
        'lastStation: 삼화상운', 현재 위치 (204439.84, 458646.53)
        'lastStation: 삼화상운', 현재 위치 (204450, 458634.22)
        'lastStation: 삼화상운', 현재 위치 (204444.7, 458640.66)
        'lastStation: 삼화상운', 현재 위치 (204450.53, 458633.66)
        'lastStation: 삼화상운', 현재 위치 (204447.97, 458636.78)
        'lastStation: 삼화상운', 현재 위치 (204450.17, 458634.12)
        'lastStation: 삼화상운', 현재 위치 (204448.67, 458635.88)
*/

오~~~ 멋집니다. ^^ 제가 워낙에 strong typing을 좋아하다 보니, 위의 API에서 사용하는 클래스들을 모두 만들어 두었고,

using System.Xml.Serialization;

namespace KoreaBusInfo.Seoul
{
    //...[생략]...

    public class BusStation
    {
        public string arsId;
        public string beginTm;
        public string busRouteId;
        public string busRouteNm;
        public string direction;
        public float gpsX;
        public float gpsY;
        public string lastTm;
        public float posX;
        public float posY;
        public int routeType;
        public int sectSpd;
        public string section;
        public int seq;
        public string station;
        public string stationNm;
        public string stationNo;
        public string transYn;
        public string fullSectDist;
        public string trnstnid;
    }

    public class BusRoute
    {
        public string busRouteId;
        public string busRouteNm;
        public string corpNm;
        public string edStationNm;

        public string firstBusTm;
        public string firstLowTm;
        public string lastBusTm;
        public string lastBusYn;
        public string lastLowTm;

        public decimal length;
        public int routeType;
        public string stStationNm;
        public int term;
    }

    public class BusPosition
    {
        public int busType;
        public int congetion;
        public string dataTm;
        public int isFullFlag;
        public string lastStnId;
        public string plainNo;
        public float posX;
        public float posY;
        public string routeId;
        public string sectDist;
        public int sectOrd;
        public string sectionId;
        public string stopFlag;
        public float tmX;
        public float tmY;
        public string vehId;
    }
}

여러분은 인텔리센스의 도움을 받으며 편하게 코딩을 하시면 됩니다. ^^

이 글의 소스 코드는 다음의 github에 올려졌으니 참고하시고,

stjeong/KoreaBusInfo
; https://github.com/stjeong/KoreaBusInfo

혹시, 위의 라이브러리에 구현되지 않은 API가 필요하다면 이슈에 올리거나, 아니면 직접 구현하셔서 PR을 주시면 기꺼이 반영을 하겠습니다. ^^




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 8/13/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2021-08-14 08시36분
[dimohy] 어느 친절하신 분의 성이 혹시 정씨신가요? ... ;; 감사합니다 ^^
[guest]
2021-08-14 05시45분
@dimohy 정말 예리한 감각의 소유자시군요. ^^
정성태

... 76  77  78  79  80  81  82  [83]  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11861정성태4/6/201919531디버깅 기술: 126. windbg - .NET x86 CLR2/CLR4 EXE의 EntryPoint
11860정성태4/5/201923381오류 유형: 527. Visual C++ 컴파일 오류 - error C2220: warning treated as error - no 'object' file generated
11859정성태4/4/201920605디버깅 기술: 125. WinDbg로 EXE의 EntryPoint에서 BP 거는 방법
11858정성태3/27/201921469VC++: 129. EXE를 LoadLibrary로 로딩해 PE 헤더에 있는 EntryPoint를 직접 호출하는 방법파일 다운로드1
11857정성태3/26/201919407VC++: 128. strncpy 사용 시 주의 사항(Linux / Windows)
11856정성태3/25/201919684VS.NET IDE: 134. 마이크로소프트의 CoreCLR 프로파일러 리눅스 예제를 Visual Studio F5 원격 디버깅하는 방법 [1]파일 다운로드1
11855정성태3/25/201921786개발 환경 구성: 436. 페이스북 HTTPS 인증을 localhost에서 테스트하는 방법
11854정성태3/25/201917485VS.NET IDE: 133. IIS Express로 호스팅하는 사이트를 https로 접근하는 방법
11853정성태3/24/201920196개발 환경 구성: 435. 존재하지 않는 IP 주소에 대한 Dns.GetHostByAddress/gethostbyaddr/GetNameInfoW 실행이 느리다면? - 두 번째 이야기 [1]
11852정성태3/20/201919516개발 환경 구성: 434. 존재하지 않는 IP 주소에 대한 Dns.GetHostByAddress/gethostbyaddr/GetNameInfoW 실행이 느리다면?파일 다운로드1
11851정성태3/19/201923274Linux: 8. C# - 리눅스 환경에서 DllImport 대신 라이브러리 동적 로드 처리 [2]
11850정성태3/18/201922245.NET Framework: 813. C# async 메서드에서 out/ref/in 유형의 인자를 사용하지 못하는 이유
11849정성태3/18/201921664.NET Framework: 812. pscp.exe 기능을 C#으로 제어하는 방법파일 다운로드1
11848정성태3/17/201918346스크립트: 14. 윈도우 CMD - 파일이 변경된 경우 파일명을 변경해 복사하고 싶다면?
11847정성태3/17/201922864Linux: 7. 리눅스 C/C++ - 공유 라이브러리 동적 로딩 후 export 함수 사용 방법파일 다운로드1
11846정성태3/15/201921468Linux: 6. getenv, setenv가 언어/운영체제마다 호환이 안 되는 문제
11845정성태3/15/201921668Linux: 5. Linux 응용 프로그램의 (C++) so 의존성 줄이기(ReleaseMinDependency) [3]
11844정성태3/14/201922971개발 환경 구성: 434. Visual Studio 2019 - 리눅스 프로젝트를 이용한 공유/실행(so/out) 프로그램 개발 환경 설정 [1]파일 다운로드1
11843정성태3/14/201917929기타: 75. MSDN 웹 사이트를 기본으로 영문 페이지로 열고 싶다면?
11842정성태3/13/201916324개발 환경 구성: 433. 마이크로소프트의 CoreCLR 프로파일러 예제를 Visual Studio CMake로 빌드하는 방법 [1]파일 다운로드1
11841정성태3/13/201916635VS.NET IDE: 132. Visual Studio 2019 - CMake의 컴파일러를 기본 g++에서 clang++로 변경
11840정성태3/13/201918216오류 유형: 526. 윈도우 10 Ubuntu App 환경에서는 USB 외장 하드 접근 불가
11839정성태3/12/201922135디버깅 기술: 124. .NET Core 웹 앱을 호스팅하는 Azure App Services의 프로세스 메모리 덤프 및 windbg 분석 개요 [3]
11838정성태3/7/201925717.NET Framework: 811. (번역글) .NET Internals Cookbook Part 1 - Exceptions, filters and corrupted processes [1]파일 다운로드1
11837정성태3/6/201939696기타: 74. 도서: 시작하세요! C# 7.3 프로그래밍 [10]
11836정성태3/5/201923230오류 유형: 525. Visual Studio 2019 Preview 4/RC - C# 8.0 Missing compiler required member 'System.Range..ctor' [1]
... 76  77  78  79  80  81  82  [83]  84  85  86  87  88  89  90  ...