Ejemplo n.º 1
0
 public function testLineIterator()
 {
     $iterator = new LineIterator(new File(__DIR__ . "/../examples/testdata.txt"));
     $c = $iterator->count();
     $conv = new Converter();
     $conv->setIteratorSource($iterator, $c - 500);
     $list = new ArrayList($conv);
     $this->assertSame(500, $list->length());
     $conv2 = new Converter();
     $conv2->setIteratorSource($iterator, 0, 499);
     $list2 = new ArrayList($conv2);
     $this->assertSame(500, $list2->length());
 }
Ejemplo n.º 2
0
// Read testdata line by line
$iterator = new LineIterator(new File(__DIR__ . "/testdata.txt"));
// Load only last 500 records
$c = $iterator->count();
$conv->setIteratorSource($iterator);
L::line("Converter created:", $watch->stop()->result());
/**
 * Create list and filter / group
 */
// Create list
$watch->start();
$list = new ArrayList($conv);
L::line("Data imported:", $watch->stop()->result());
// Stats
echo "\n";
L::line($list->length(), "records");
L::line("First record:", $list->first()->timestamp->format('Y-m-d H:i:s'));
L::line("Last record:", $list->last()->timestamp->format('Y-m-d H:i:s'));
echo "\n";
// Only the newest day, group by hour
$watch->start();
$dates = $list->distinct(function ($v) {
    return $v->timestamp->format('Y-m-d');
})->take(-2)->select(function ($v) {
    return $v->timestamp->format('Y-m-d');
});
$hours = $list->where(function (ObjectArray $r) use($list, $dates) {
    return in_array($r->timestamp->format('Y-m-d'), $dates);
})->groupBy(function (ObjectArray $r) {
    return $r->timestamp->format('Y-m-d H:00');
});