The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]



"Красиво собрать массив из глубин JSON"
Версия для распечатки Пред. тема | След. тема
Форум WEB технологии
Исходное сообщение [ Отслеживать ]

. "re: не взлетит" +/
Сообщение от Шёл мимо (?), 10-Авг-19, 09:18 
> не взлетит


#!/usr/bin/perl

use strict;
use warnings;
use JSON;
use Data::Dumper;
use Benchmark 'cmpthese';

my $json_text = '[
{
  "id" : "1",
  "name" : "Name1"
},
{
  "id" : "2",
  "name" : "Name2"
},
{
  "id" : "3",
  "name" : "Name3"
}]'
;

#my $json = JSON->new->decode($json_text);
my $json = decode_json($json_text);

print Dumper($json);

sub mapng {
    my @names = map { $_->{name} } @{$json};

}

sub modif {
    push my @names, $_->{name} for @{$json};
}

sub cycle {
    for ( @{$json} ) {
        push my @names, $_->{name};
    }
}
sub ptext {
    my @names = ($_[0] =~ /^\s*+"name" *+: *+"([^"]*+)"/mg);
#    print Dumper(@names);
}
#ptext($json_text);

cmpthese(
  -1,
  {
    'mapng' => sub { mapng($json) },
    'modif' => sub { modif($json) },
    'cycle' => sub { cycle($json) },
    'ptext' => sub { ptext($json_text) },
  }
);
__END__


ptext  92781/s    --  -63%  -67%  -67%
mapng 251601/s  171%    --  -11%  -12%
cycle 281553/s  203%   12%    --   -1%
modif 284630/s  207%   13%    1%    --

Если правильно понял

Ответить | Правка | Наверх | Cообщить модератору

Оглавление
Красиво собрать массив из глубин JSON, GoldenCeylon, 08-Фев-19, 09:13  [смотреть все]
Форумы | Темы | Пред. тема | След. тема



Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2024 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру