Method: RedAmber::Group#summarize
- Defined in:
- lib/red_amber/group.rb
#summarize {|group| ... } ⇒ DataFrame #summarize {|group| ... } ⇒ DataFrame #summarize {|group| ... } ⇒ DataFrame
Summarize Group by aggregation functions from the block.
549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 |
# File 'lib/red_amber/group.rb', line 549 def summarize(*args, &block) if block agg = instance_eval(&block) unless args.empty? agg = [agg] if agg.is_a?(DataFrame) agg = args.zip(agg).to_h end else agg = args end case agg when DataFrame agg when Array aggregations = agg.map do |df| v = df.vectors[-1] [v.key, v] end agg[0].assign(aggregations) when Hash aggregations = agg.map do |key, df| aggregated_keys = df.keys - @group_keys if aggregated_keys.size > 1 = "accept only one column from the Hash: #{aggregated_keys.join(', ')}" raise GroupArgumentError, end v = df.vectors[-1] [key, v] end agg.values[-1].drop(-1).assign(aggregations) else raise GroupArgumentError, "Unknown argument: #{agg}" end end |