protected function execute(InputInterface $input, OutputInterface $output) { $conn = DB::getConn(); $data = $conn->fetchAll('SELECT * FROM variants'); if (!empty($data)) { $result = []; foreach ($data as $row) { $result[$row['test_name']]['test_name'] = $row['test_name']; $result[$row['test_name']]['shows'] = 0; $result[$row['test_name']]['goals'] = 0; } foreach ($data as $row) { $result[$row['test_name']]['shows'] += $row['shows']; $result[$row['test_name']]['goals'] += $row['goals']; } foreach ($data as $row) { $result[$row['test_name']]['conversion'] = $row['goals'] / $row['shows'] * 100 . " %"; } $table = new Table($output); $table->setHeaders(['Test name', 'Totals shows', 'Totals goals', 'Total conversion'])->setRows($result); $table->render(); } else { $output->writeln('<error>Test list is empty</error>'); } }
protected function execute(InputInterface $input, OutputInterface $output) { $name = $input->getArgument('name'); $conn = DB::getConn(); $data = $conn->fetchAll('SELECT * FROM variants WHERE test_name = ?', [$name]); if (!empty($data)) { $result = []; foreach ($data as $row) { $result[$row['variant']]['variant'] = $row['variant']; $result[$row['variant']]['shows'] = $row['shows']; $result[$row['variant']]['goals'] = $row['goals']; $result[$row['variant']]['conversion'] = $row['goals'] / $row['shows'] * 100 . ' %'; } $table = new Table($output); $table->setHeaders([[new TableCell('A\\B test results for "' . $name . '"', ['colspan' => 4])], ['Variant name', 'Shows', 'Goals', 'Conversion']])->setRows($result); $table->render(); } else { $output->writeln('<error>Test with name "' . $name . '" not found</error>'); } }