NEWS
Вопросы по написанию скриптов
-
Почему эта строчка отрабатывает
else if ( temp_in < temp_base - circ_hyst && cur_temp < temp_base - circ_hyst )temp_base - circ_hyst получается 19.85
а эта нет ?
else if ( temp_in > temp_base + circ_hyst && cur_temp > temp_base + circ_hyst )temp_base + circ_hyst получается 20.000.15
-
Потому что их обрабатывает как текстовые, делайте через````
parseFloat(temp_base) + ParseFloat(circle_hyst)```` `
Спасибо spectrekr, с parseFloat конечно работает но это костыль. Проблема заключается в том что я экспериментируя с скриптом заметил странную особенность что иногда всё работает как надо а иногда неправильно. Так как эти переменные часто меняю для всевозможных экспериментов с скриптом по старой привычке менял значение в вкладке "состояние" и всё было хорошо. Когда появилась возможность менять значение переменной в вкладке объекты тут и началось. Bluefox наверно так не должно быть ? -
Потому что их обрабатывает как текстовые, делайте через````
parseFloat(temp_base) + ParseFloat(circle_hyst)````
Спасибо spectrekr, с parseFloat конечно работает но это костыль. Проблема заключается в том что я экспериментируя с скриптом заметил странную особенность что иногда всё работает как надо а иногда неправильно. Так как эти переменные часто меняю для всевозможных экспериментов с скриптом по старой привычке менял значение в вкладке "состояние" и всё было хорошо. Когда появилась возможность менять значение переменной в вкладке объекты тут и началось. Bluefox наверно так не должно быть ?
Такая же история. Когда меняю значение переменной через Telegram через Text2Command, по логу Text2Command отрабатывает чётко, а вот в скрипте, в котором подписка на изменение переменной - он то сразу сработает, то ровно через 5 мин, то вообще не работает…function download (uri, filename, callback){ request.head(uri, function(err, res, body){ request(uri).pipe(fs.createWriteStream(filename)).on('close', callback); }); } var fs = require('fs'); var request = require('request'); on({id:'javascript.0.send_cameras', change: 'any'}, function (obj) { if (!fs.existsSync('C:/cameras/')) { console.error('Directory for cameras does not exist'); } else { download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){ console.log('Camera 1 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg'); }); download('http://192.168.0.222:11000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera2.jpg', function(){ console.log('Camera 2 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera2.jpg'); }); download('http://192.168.0.222:13000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera3.jpg', function(){ console.log('Camera 3 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera3.jpg'); }); download('http://192.168.0.222:14000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera4.jpg', function(){ console.log('Camera 4 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera4.jpg'); }); } });Хотя есть код -
on({id: "mqtt.0.flat129.PIR1", "change": "any"}, function (obj) { pir1 = getState("mqtt.0.flat129.PIR1").val; log('Информацию с дачтка 1 увидели...'); var date = new Date(); log('OK'); sendTo("telegram.0", "Датчик 1!"); log('Датчик 1 отправили!'); });отрабатывает чётко и всегда!
В этих случаях вижу лишь одну разницу (в первом скрипте переменная не подтверждена (false), a во втором подтверждена всегда (true).
Может в этом причина?
Может как-то зависит от версии Node.JS?
-
Я с проблемой текст в цифры столкнулся при подключении счётчика через mqtt клиент, счётчик числа передавал, а скрипт их как слова складывал, вот и пришлось искать решение как явно указать что там числа. По поводу подписки на переменную, тоже имею проблему. Явно меняю переменную, процедура отрабатывает, переменная меняется скриптом - процедура в тишине.
Отправлено с моего C6603 через Tapatalk
-
Такая же история. Когда меняю значение переменной через Telegram через Text2Command, по логу Text2Command отрабатывает чётко, а вот в скрипте, в котором подписка на изменение переменной - он то сразу сработает, то ровно через 5 мин, то вообще не работает…
function download (uri, filename, callback){ request.head(uri, function(err, res, body){ request(uri).pipe(fs.createWriteStream(filename)).on('close', callback); }); } var fs = require('fs'); var request = require('request'); on({id:'javascript.0.send_cameras', change: 'any'}, function (obj) { if (!fs.existsSync('C:/cameras/')) { console.error('Directory for cameras does not exist'); } else { download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){ console.log('Camera 1 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg'); }); download('http://192.168.0.222:11000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera2.jpg', function(){ console.log('Camera 2 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera2.jpg'); }); download('http://192.168.0.222:13000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera3.jpg', function(){ console.log('Camera 3 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera3.jpg'); }); download('http://192.168.0.222:14000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera4.jpg', function(){ console.log('Camera 4 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera4.jpg'); }); } }); ```` `А что ты пытаешся этим скриптом сделать? сколько времени у тебя отрабатывает функция download ?
А если так?
! ````
function download (uri, filename, callback){
request.head(uri, function(err, res, body){
request(uri).pipe(fs.createWriteStream(filename)).on('close', callback);
});
}
var fs = require('fs');
var request = require('request');
! on({id:'javascript.0.send_cameras', change: 'any'}, function (obj) {
if (!fs.existsSync('C:/cameras/')) {
console.error('Directory for cameras does not exist');
} else {
download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){
console.log('Camera 1 copying done!');
sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg');
download('http://192.168.0.222:11000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera2.jpg', function(){
console.log('Camera 2 copying done!');
sendTo("telegram.0", 'C:/Users/User/Pictures/camera2.jpg');
download('http://192.168.0.222:13000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera3.jpg', function(){
console.log('Camera 3 copying done!');
sendTo("telegram.0", 'C:/Users/User/Pictures/camera3.jpg');
download('http://192.168.0.222:14000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera4.jpg', function(){
console.log('Camera 4 copying done!');
sendTo("telegram.0", 'C:/Users/User/Pictures/camera4.jpg');
});
});
});
});
! }
}); -
Потому что их обрабатывает как текстовые, делайте через````
parseFloat(temp_base) + ParseFloat(circle_hyst)````
Спасибо spectrekr, с parseFloat конечно работает но это костыль. Проблема заключается в том что я экспериментируя с скриптом заметил странную особенность что иногда всё работает как надо а иногда неправильно. Так как эти переменные часто меняю для всевозможных экспериментов с скриптом по старой привычке менял значение в вкладке "состояние" и всё было хорошо. Когда появилась возможность менять значение переменной в вкладке объекты тут и началось. Bluefox наверно так не должно быть ?
Это не костыль, это JS -
А что ты пытаешся этим скриптом сделать? сколько времени у тебя отрабатывает функция download ?
А если так?
!
function download (uri, filename, callback){ request.head(uri, function(err, res, body){ request(uri).pipe(fs.createWriteStream(filename)).on('close', callback); }); } var fs = require('fs'); var request = require('request'); ! on({id:'javascript.0.send_cameras', change: 'any'}, function (obj) { if (!fs.existsSync('C:/cameras/')) { console.error('Directory for cameras does not exist'); } else { download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){ console.log('Camera 1 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg'); download('http://192.168.0.222:11000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera2.jpg', function(){ console.log('Camera 2 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera2.jpg'); download('http://192.168.0.222:13000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera3.jpg', function(){ console.log('Camera 3 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera3.jpg'); download('http://192.168.0.222:14000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera4.jpg', function(){ console.log('Camera 4 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera4.jpg'); }); }); }); }); ! } });`
Этот скрипт загружает статические картинки с видеокамер, каждая размером 110-250 кб (сек 20-30 всего).Потом кидаю в Telegram.
Твой скрипт работает стабильнее ), но всё равно через 2-3 раза…
! javascript-0 2016-04-21 19:27:24 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera1.jpg"
! javascript-0 2016-04-21 19:27:24 info script.js.cameras: Camera 1 copying done!
! javascript-0 2016-04-21 19:27:23 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera2.jpg"
! javascript-0 2016-04-21 19:27:23 info script.js.cameras: Camera 2 copying done!
! javascript-0 2016-04-21 19:27:17 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera3.jpg"
! javascript-0 2016-04-21 19:27:17 info script.js.cameras: Camera 3 copying done!
! javascript-0 2016-04-21 19:27:10 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera4.jpg"
! javascript-0 2016-04-21 19:27:10 info script.js.cameras: Camera 4 copying done!
! mqtt-0 2016-04-21 19:27:02 info send2Server admin.1.send_cameras[admin/1/send_cameras]
! text2command-0 2016-04-21 19:27:02 info sendTo "send" to system.adapter.telegram.0 from system.adapter.text2command.0: {"text":"стройка","id":60629447,"user":"ссс","response":""}
! text2command-0 2016-04-21 19:27:02 info Say ID admin.1.send_cameras: true
! text2command-0 2016-04-21 19:27:02 info processText: "камеры"
C одной камерой такая же ерунда..! ````
function download (uri, filename, callback){
request.head(uri, function(err, res, body){
request(uri).pipe(fs.createWriteStream(filename)).on('close', callback);
});
}
var fs = require('fs');
var request = require('request');
! on({id:"admin.1.send_cameras", change: 'any'}, function (obj) {
if (!fs.existsSync('C:/cameras/')) {
console.error('Directory for cameras does not exist');
} else {
download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){
console.log('Camera 1 copying done!');
sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg');});! }
}); -
Потому что их обрабатывает как текстовые, делайте через````
parseFloat(temp_base) + ParseFloat(circle_hyst)````
Спасибо spectrekr, с parseFloat конечно работает но это костыль. Проблема заключается в том что я экспериментируя с скриптом заметил странную особенность что иногда всё работает как надо а иногда неправильно. Так как эти переменные часто меняю для всевозможных экспериментов с скриптом по старой привычке менял значение в вкладке "состояние" и всё было хорошо. Когда появилась возможность менять значение переменной в вкладке объекты тут и началось. Bluefox наверно так не должно быть ?
Это не костыль, это JS `
Костыль :) я имел виду в else if ( temp_in > (parseFloat(temp_base) + parseFloat(circ_hyst)) && cur_temp > (parseFloat(temp_base) + parseFloat(circ_hyst)) ) , проблема оказалось в возможности менять значение переменной в вкладке объекты. Тут скорей всего недоработка какая та. :?:PS. Вот и немцы пишут
paul53 писал (а): Как вы проверить? Надеюсь , не изменять значения в закладке "Объекты", потому что он работает (пока) не должным образом. -
А что ты пытаешся этим скриптом сделать? сколько времени у тебя отрабатывает функция download ?
А если так?
!
function download (uri, filename, callback){ request.head(uri, function(err, res, body){ request(uri).pipe(fs.createWriteStream(filename)).on('close', callback); }); } var fs = require('fs'); var request = require('request'); ! on({id:'javascript.0.send_cameras', change: 'any'}, function (obj) { if (!fs.existsSync('C:/cameras/')) { console.error('Directory for cameras does not exist'); } else { download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){ console.log('Camera 1 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg'); download('http://192.168.0.222:11000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera2.jpg', function(){ console.log('Camera 2 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera2.jpg'); download('http://192.168.0.222:13000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera3.jpg', function(){ console.log('Camera 3 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera3.jpg'); download('http://192.168.0.222:14000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera4.jpg', function(){ console.log('Camera 4 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera4.jpg'); }); }); }); }); ! } });`
Этот скрипт загружает статические картинки с видеокамер, каждая размером 110-250 кб (сек 20-30 всего).Потом кидаю в Telegram.
Твой скрипт работает стабильнее ), но всё равно через 2-3 раза…
! javascript-0 2016-04-21 19:27:24 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera1.jpg"
! javascript-0 2016-04-21 19:27:24 info script.js.cameras: Camera 1 copying done!
! javascript-0 2016-04-21 19:27:23 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera2.jpg"
! javascript-0 2016-04-21 19:27:23 info script.js.cameras: Camera 2 copying done!
! javascript-0 2016-04-21 19:27:17 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera3.jpg"
! javascript-0 2016-04-21 19:27:17 info script.js.cameras: Camera 3 copying done!
! javascript-0 2016-04-21 19:27:10 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera4.jpg"
! javascript-0 2016-04-21 19:27:10 info script.js.cameras: Camera 4 copying done!
! mqtt-0 2016-04-21 19:27:02 info send2Server admin.1.send_cameras[admin/1/send_cameras]
! text2command-0 2016-04-21 19:27:02 info sendTo "send" to system.adapter.telegram.0 from system.adapter.text2command.0: {"text":"стройка","id":60629447,"user":"ссс","response":""}
! text2command-0 2016-04-21 19:27:02 info Say ID admin.1.send_cameras: true
! text2command-0 2016-04-21 19:27:02 info processText: "камеры"
C одной камерой такая же ерунда..! ````
function download (uri, filename, callback){
request.head(uri, function(err, res, body){
request(uri).pipe(fs.createWriteStream(filename)).on('close', callback);
});
}
var fs = require('fs');
var request = require('request');
! on({id:"admin.1.send_cameras", change: 'any'}, function (obj) {
if (!fs.existsSync('C:/cameras/')) {
console.error('Directory for cameras does not exist');
} else {
download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){
console.log('Camera 1 copying done!');
sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg');});! }
});
```` ` что значит через два три раза? Может у тебя ошибкой завершается копирование? Ты не ловиш в скрипте ошибки а отрабатываешь код дальше -
Дело в скрипте, это работает чётко:
var fs = require('fs'), request = require('request'); var download = function(uri, filename, callback){ var r = request({ url: uri, headers: { 'accept': 'image/*', 'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.118 Safari/537.36', } }).pipe(fs.createWriteStream(filename)); r.on('error', function(err) {console.log(err)}) r.on('close', callback); }; on({id:"admin.1.send_cameras", change: 'any'}, function (obj) { download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){ console.log('Сamera 1 copying done'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg'); }); download('http://192.168.0.222:11000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera2.jpg', function(){ console.log('Camera 2 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera2.jpg'); }); download('http://192.168.0.222:13000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera3.jpg', function(){ console.log('Camera 3 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera3.jpg'); }); download('http://192.168.0.222:14000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera4.jpg', function(){ console.log('Camera 4 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera4.jpg'); }); }); -
Записываю в log_heat.txt "log_heat", может как то по другому надо ? ( log_heat может быть много, в зависимости от условий по скрипту)
function getTimeAsString(d) { var date = d || new Date(); return ('0' + (date.getMonth() + 1)).slice(-2) + '/' + ('0' + date.getDate()).slice(-2) + ' '+ ('0' + date.getHours()).slice(-2) + ':' + ('0' + date.getMinutes()).slice(-2) + ':' + ('0' + date.getSeconds()).slice(-2); } function script (addTimestamp) { var fs = require('fs'); var log_heat; log_heat = ( getTimeAsString() + ' ' + 'Температура бака'); fs.appendFileSync('//opt//log_heat.txt', log_heat + "\n"); log_heat = ( getTimeAsString() + ' ' + 'Температура бакаaaaaaaaaaaaaa'); fs.appendFileSync('//opt//log_heat.txt', log_heat + "\n"); } function start () { var request = require ( 'request' ); request ( 'http://192.168.1.11/avr_temp_out.php', function ( error, response, body ) { if ( !error && response.statusCode == 200 ) { //setState ( toaid, body ); log('1 avr_temp_out: ' + body); } setTimeout ( function () { script (); }, 1000 ); }); } setInterval ( function () { start (); }, 30000 ); -
Хочу заставить бота слать информацию об обновлении, подписываюсь на драйвер, а он либо undefined присылает, либо вообще молчит.
on({id: 'admin.0.info.updatesList', change: 'any'}, function (obj) { if (getState('admin.0.info.updatesNumber').val > 0){ sendTo('telegram', obj.val); log(obj.val); } }); -
Хочу заставить бота слать информацию об обновлении, подписываюсь на драйвер, а он либо undefined присылает, либо вообще молчит.
on({id: 'admin.0.info.updatesList', change: 'any'}, function (obj) { if (getState('admin.0.info.updatesNumber').val > 0){ sendTo('telegram', obj.val); log(obj.val); } }); ```` `Вроде id: лишние
Пишу с пульта….
-
Так везде и всегда так подписываюсь на изменения, и в примерах так описано. Да и он отслеживает изменения и запускает на выполнение, только вот, насколько я понял, значение объекта в текст не может перевести. `
Obj.val.toString() -
Хочу заставить бота слать информацию об обновлении, подписываюсь на драйвер, а он либо undefined присылает, либо вообще молчит.
on({id: 'admin.0.info.updatesList', change: 'any'}, function (obj) { if (getState('admin.0.info.updatesNumber').val > 0){ sendTo('telegram', obj.val); log(obj.val); } }); ```` `on({id: 'admin.0.info.updatesNumber', change: 'any'}, function (obj) { if (obj.newState.val > 0){ sendTo('telegram', (obj.newState.val).toString()); log(obj.newState.val); } });А если так?
Hello! It looks like you're interested in this conversation, but you don't have an account yet.
Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.
With your input, this post could be even better 💗
Register Login