now that I've finally switched to websocket in Binance, I cant parse data from the response anymore like I used to do with my old script. I am using Javascript with Google Apps Script
function balanceBinance() {
var key = '';
var secret = '';
var curTime = Number(new Date().getTime()).toFixed(0);
var string = "type=SPOT×tamp=" + curTime;
var sKey = Utilities.computeHmacSha256Signature(string, secret);
sKey = sKey.map(function(e) {
var v = (e < 0 ? e + 256 : e).toString(16);
return v.length == 1 ? "0" + v : v;
}).join("");
var params = {
'type':'SPOT',
'method': 'GET',
'headers': {'X-MBX-APIKEY': key},
'muteHttpExceptions': true
};
var url = "https://api.binance.com/sapi/v1/accountSnapshot?" + string + "&signature=" + sKey;
var data = UrlFetchApp.fetch(url, params);
var data = JSON.parse(data.getContentText());
var data = data.snapshotVos;
Logger.log(data);
}
it returns:
[{data={totalAssetOfBtc=0.0000117, balances=[{free=0.0000117, asset=BNB, locked=0}, {asset=BTC, locked=0, free=0.00000093}, {free=0.00026, asset=BTCDOWN, locked=0}, {locked=0, free=0.00, asset=EUR}, {asset=USDT, locked=0, free=0.06716916}]}, type=spot, updateTime=1.622851199E12}, {updateTime=1.622937599E12, data={totalAssetOfBtc=0.0000117, balances=[{asset=BNB, locked=0, free=0.0000117}, {locked=0, asset=BTC, free=0.00000093}, {locked=0, free=0.00026, asset=BTCDOWN}, {locked=0, free=0.34585555, asset=EUR}, {free=0.06716916, locked=0, asset=USDT}]}, type=spot}, {type=spot, updateTime=1.623023999E12, data={balances=[{locked=0, asset=BNB, free=0.0000117}, {asset=BTC, locked=0, free=0.00000093}, {asset=BTCDOWN, locked=0, free=0.00026}, {free=0.34585555, locked=0, asset=EUR}, {free=411.06716916, locked=0, asset=USDT}], totalAssetOfBtc=0.11298258}}, {updateTime=1.623110399E12, type=spot, data={balances=[{free=0.0000117, locked=0, asset=BNB}, {asset=BTC, locked=0, free=0.00000093}, {locked=0, asset=BTCDOWN, free=0.00026}, {asset=ETHDOWN, free=0.00376, locked=0}, {free=0.34585555, asset=EUR, locked=0}, {free=0.40578148, locked=0, asset=USDT}], totalAssetOfBtc=0.0000117}}, {data={totalAssetOfBtc=0.0000117, balances=[{free=0.0000117, locked=0, asset=BNB}, {free=0.00000093, asset=BTC, locked=0}, {free=0.00026, asset=BTCDOWN, locked=0}, {free=0.00376, asset=ETHDOWN, locked=0}, {free=0.34585555, asset=EUR, locked=0}, {free=0.40578148, locked=0, asset=USDT}]}, type=spot, updateTime=1.623196799E12}]
in the previous version of the script I was able to extract the free paramater for any corresponding asset, with the following code:
var data = data.filter(function (el) {
return el.free > 0;
});
var i;
for (i=0; i < data.length; i++) {
var asset = data[i].asset;
var free = data[i].free;
if (free < 1) {var a = parseFloat(free); var a = a.toFixed(8); var free = parseFloat(a);}
if (free > 1 && free < 10) {var a = parseFloat(free); var a = a.toFixed(4); var free = parseFloat(a);}
if (free >=10) {var a = parseFloat(free); var a = a.toFixed(2); var free = parseFloat(a);}
var row=rows.indexOf(asset)+2;
if (row>0){
sheet.getRange(row, 13).setValue(free);}
}