Ошибка синтаксиса: неожиданный конец ввода JSON: OpenALPR с использованием Node и Javascript - PullRequest
0 голосов
/ 02 мая 2020

При использовании оператора try / catch для объявления var data программа выдаст сообщение «Номерной знак не найден», даже если он есть. Если оператор try / catch удален, программа печатает отлично, когда в кадре нет номерного знака, но когда он есть, я получаю SyntaxError. Node.js и OpenALPR установлены. Фотографии также успешно принимаются. Требуется эксперт OpenALPR.

const PiCamera = require('pi-camera');


function getRandomInt(max) {
    return Math.floor(Math.random() * Math.floor(max));
}

setInterval(function() {

    var path = './' + getRandomInt(500) + '.jpg';

    const myCamera = new PiCamera({
        mode: 'photo',
        output: path,
        width: 1920,
        height: 1080,
        nopreview: false,
    });


    myCamera.snap()
        .then((result) => {

            var exec = require('child_process').exec;
            var cmd = 'alpr -c eu -n 1 --json ' + path;

            exec(cmd, function(error, stdout, stderr) {

            console.log(stdout);

            try {
               var data = JSON.parse(stdout.trim())
            } catch (e) {
               console.error('Failed to Parse JSON!', e)
            }

                if (data && data.results &&  data.results.length > 0) {
                    console.log(data.results[0].plate);
                } else {
                    console.log("\n\n\nNo license plate found.\n\n");
                }
            });

            console.log(result);

        })
        .catch((error) => {
            console.log(error);
        });

}, 2e3);

Ошибка и место ее возникновения без try / catch:

  undefined:1
  SyntaxError: Unexpected end of JSON input
    at JSON.parse (<anonymous>)
    at /home/pi/Project/project.js:28:33
    at ChildProcess.exithandler (child_process.js:301:5)
    at ChildProcess.emit (events.js:189:13)
    at maybeClose (internal/child_process.js:970:16)
    at Socket.stream.socket.on (internal/child_process.js:389:11)
    at Socket.emit (events.js:189:13)
    at Pipe._handle.close (net.js:600:12)

Вывод console.log(stdout); до var data объявление:

{"version":2,"data_type":"alpr_results","epoch_time":1588355061888,"img_width":1920,"img_height":1080,"processing_time_ms":1447.340698,"regions_of_interest":[],"results":[]}

1 Ответ

1 голос
/ 02 мая 2020
  1. данные уже проанализированы. ошибка выдается, потому что вы пытаетесь разобрать ее снова.

  2. .trim () - строковая операция. то, с чем вы имеете дело, это json объект. так что это тоже недействительно. JSON .stringify (stdout) .trim () действительно, хотя.

...