스누피(snoopy) 다운 및 이용 방법은 아래 페이지에서 먼저 확인 부탁 드립니다.


http://hatpub.tistory.com/39?category=988325

<?
include_once 'Snoopy.class.php';
$snoopy = new snoopy;
$snoopy->fetch("https://bittrex.com/api/v1.1/public/getmarketsummaries");
$t	 = $snoopy->results;

preg_match_all("|MarketName\":\"(.*)\",\"High\"|U", $t, $name, PREG_SET_ORDER);
preg_match_all("|\"BaseVolume\":(.*),\"TimeStamp\":|U", $t, $volume, PREG_SET_ORDER);
preg_match_all("|Last\":(.*),\"BaseVolume\"|U", $t, $price, PREG_SET_ORDER);

?>

업로드된 Snopy.class.php 파일을 먼저 인클루드 한뒤,


Json 형태의 API 사이트를 fetch 에 담아 $t 변수에 넣습니다.


preg_match_all 함수를 이용 하여 MarketName(코인명) 은 $name 변수에,

 Last(최근거래가격)은 $price 변수에, BaseVolume(24시간비트볼륨) 은 $volume 변수에 항목의 모든 값을 2차 배열로 담아 옵니다.



↓ https://bittrex.com/api/v1.1/public/getmarketsummaries 접속 시 Json 형태의 값으로 아래 이미지와 같이 표시 됩니다.





<?
$int = 0;
$var = "insert into bittrex(name, price, volume) values";

WHILE($int < count($name)){
	if($int == 0){
		$var = $var."(".$name[$int][1]."',".$price[$int][1].",".$volume[$int][1].")";
	}else{
		$var = $var.",(".$name[$int][1]."',".$price[$int][1].",".$volume[$int][1].")";
	}
	$int++;
}

mysqli_query($conn, $var);
?>


$name, $price, $volume 에 담아온 값을 WHILE 을 사용하여 쿼리문을 작성 합니다.


마지막으로 mysql insert 문을 실행 시키면 값이 DB에 저장 되게 됩니다.


※ 스누피는 PHP 로 작성 되어 있습니다. PHP 환경에서 정상 작동 합니다.




1. 스누피 다운로드


다운로드 주소 

http://sourceforge.net/projects/snoopy/files/latest/download



1) 다운로드 후 압축해제



2) 압축 해제한 파일 전부를 서버(웹호스팅) 으로 업로드


업로드가 완료 되었으면, 설치는 끝났습니다. 참 쉽죠?






2. PHP 페이지 내 스누피 불러오기 및 적용.




	// 스누피 인클루드 (경로 주의 하세요)
	include_once './insert/Snoopy.class.php';
	// 스누피 객체 생성
	$snoopy = new snoopy;
	// fetch를 이용하여 스누피 객체에 빗썸 API의 모든 내용 담기
	$snoopy -> fetch("https://api.bithumb.com/public/ticker/all");
	// 담은 값을 $result 객체에 담기
	$result = $snoopy->results;
	
	// 출력
	echo $result;


※ 위엣 값을 입력 하시고 저장하시면 웹에서 API 사이트에 있는 내용을 모두 담아 옵니다.

(출력되는 페이지의 내용이 https://api.bithumb.com/public/ticker/all 사이트의 내용과 동일합니다.)






3. preg_match_all 을 사용하여 원하는 값 추출



빗썸의 BTC 현재가만 분리해서 값을 가져오도록 해보겠습니다.

(빗썸의 현재가는 "closing_price" 의 값을 가져 오면 됩니다.)


▼ 빗썸 API 페이지

API 페이지에 보시면 위의 이미지의 내용들이 아래와 같이 한줄로 들어 있습니다.

{"BTC":{"opening_price":"12633000","closing_price":"11351000","min_price":"10555000","max_price":"12650000","average_price":"11720488.0444","units_traded":"11983.63012161","volume_1day":"11983.63012161","volume_7day":"80223.98672679","buy_price":"11352000","sell_price":"11358000"}




위 내용 중 closing_pricemin_price 사이의 값인 11351000 PREG_MATCH_ALL 을 이용하여 추출 해보겠습니다.


	// 스누피 인클루드 (경로 주의 하세요)
	include_once './insert/Snoopy.class.php';
	// 스누피 객체 생성
	$snoopy = new snoopy;
	// fetch를 이용하여 스누피 객체에 빗썸 API의 모든 내용 담기
	$snoopy -> fetch("https://api.bithumb.com/public/ticker/all");
	// 담은 값을 $result 객체에 담기
	$result = $snoopy->results;
	
	// 출력
	//echo $result;
	
	preg_match_all("|closing_price\":\"(.*)\",\"min_price|U", $result, $name, PREG_SET_ORDER);
	
	echo 'BITHUMB BTC PRICE : '.$name[0][1];


※ preg_match_all 에서 받은 $name 변수는 위와 같이 배열로 출력 하셔야 합니다.


PREG_MATCH_ALL 의 내용을 좀 더 자세히 공부하고 싶으신 분은 아래 링크 참조 하세요!

http://php.net/manual/en/function.preg-match-all.php





4. 결과






거래소 별 최근 거래 내역 API 를 json 형태로 받아 올수 있는 사이트 링크입니다.

아래 API 를 활용 하여 저는 실시간으로 가격 급등, 급락 코인과

거래소별 코인 가격비교 하는 사이트를 만들어 보았습니다.

http://rocketchart.net

저는 파이썬을 이용하지 않고 PHP와 스누피(snoopy)를 이용하여 데이터를 크롤링 하여 DB에 넣은 뒤

뽑아 내었는데요. snoopy 를 이용하여 크롤링 하는 방법은 다음 포스팅에 올리겠습니다.


※ 파이썬으로 API 를 가져 오는 것을 공부 하신다면, 아래 사이트에 잘 정리 되어 있습니다.

https://i.k-june.com/wp/4560


1. 국내 거래소


코인원(coinone) API

https://api.coinone.co.kr/ticker/?currency=all&format=json

빗썸(bithumb) API     

https://api.bithumb.com/public/ticker/all

코빗(korbit) API             

https://api.korbit.co.kr/v1/ticker?currency_pair=btc_krw

코인네스트(Coinnest) API    

https://www.coinnest.co.kr/api/pub/ticker

코인레일(coinrail) API

https://api.coinrail.co.kr/public/last/order?currency=qtum-btc



2. 해외 거래소


bittrex API

https://bittrex.com/api/v1.1/public/getmarketsummaries

poloniex API

https://poloniex.com/public?command=returnTicker

bitfinex API

https://api.bitfinex.com/v1/tickers

kraken API

https://api.kraken.com/0/public/Ticker?pair=BCHXBT,DASHXBT(필요한 코인 추가)

hitbtc API         

https://api.hitbtc.com/api/1/public/ticker

binance API

https://api.binance.com/api/v1/ticker/24hr

quoine API

https://api.quoine.com/products

yobit API         

https://yobit.net/api/3/ticker/eth_btc-lsk_btc(필요한 코인 추가)

liqui API         

https://api.liqui.io/api/3/ticker/trx_btc-ast_btc(필요한 코인 추가)

GDAX API

https://api-public.sandbox.gdax.com/products/ETH-BTC/ticker

bitstamp API

https://www.bitstamp.net/api/v2/ticker/xrpbtc (ltcbtc,ethbtc)

okcoin API

https://www.okcoin.com/api/v1/ticker.do?symbol=btc_usd

Zaif API           

https://api.zaif.jp/api/1/currency_pairs/all

kucoin API

https://api.kucoin.com/v1/market/open/symbols

bitflyer API       

https://api.bitflyer.jp/v1/getticker


※ OKex 거래소는 사이트 접속이 안되어 구하지 못하였습니다.


위의 링크 이동 시, 아래와 같이 json 형태로 보이신다면 정상 입니다.!



+ Recent posts