Hi Perl Monks, I need help to get the total number of my customer data. Here's the current script I am using:

#!/usr/bin/perl # # use warnings; use strict; my $cust_file = "customer.txt"; my $billing_file = "20100301.bill"; my $lastmonth_period = "1Feb2010 - 28Feb2010"; my $cust; open (CUST_DATA, $cust_file) || die "Can't read '$cust_file': $!\n"; while (defined (my $line = <CUST_DATA>)) { chomp $line; # Remove trailing newline my ($cust_id,$cust_name) = split(/:/,$line); $cust->{$cust_id}->{name} = $cust_name; } close(CUST_DATA); my @bill_fields = qw(cust_id x_cust_id2 Device_Code Port Traf_Dir x_st +art_date x_end_date x_number Data_Usage); my $bill_line; my $bill_data; open(BILL_DATA, $billing_file) || die "Can't read '$billing_file': $!\ +n"; while (defined (my $line = <BILL_DATA>)) { chomp $line; # Remove trailing newline @{$bill_line}{@bill_fields} = split(/\s/, $line); $bill_data->{ $bill_line->{cust_id} }->{ $bill_line->{Device_Code} + }->{ $bill_line->{Port} }->{ $bill_line->{Traf_Dir} } = $bill_line-> +{Data_Usage}; } close(BILL_DATA); sub by_name ($$) { return $cust->{$a}->{name} <=> $cust->{$b}->{name} +}; for my $customer ( keys %$cust ) { # Write to a file named with the customer name my $output = "./$cust->{$customer}->{name}.txt"; open (CUST_OUT, ">$output") || die "Can't write to '$output': $!\n +"; print CUST_OUT "Data Transfer Report for $cust->{$customer}->{name +}\n" . "Period Device_Code Port T +raf_Dir Data_Usage\n"; for my $device ( sort by_name keys %{$bill_data->{$customer}} ) { for my $port ( sort keys %{$bill_data->{$customer}->{$device}} + ) { (my $short_port = $port) =~ s/^FastEthernet/Fa/g; for my $direction qw(OUT IN) { print CUST_OUT "$lastmonth_period $device $short_port +$direction" . $bill_data ->{$customer}->{$device}->{$port}->{$di +rection} . $/; } } } close(CUST_OUT); }


Current output:

Data Transfer Report for ABC Period Device_Code Port Traf_Dir Data_Usage
1Feb2010 - 28Feb2010 SWITCH Fa1_0_1 OUT129.641
1Feb2010 - 28Feb2010 SWITCH Fa1_0_1 IN50.947
1Feb2010 - 28Feb2010 SWITCH Fa1_0_2 OUT19.723
1Feb2010 - 28Feb2010 SWITCH Fa1_0_2 IN11.478

I need to compute the total Data Usage such as:

Data Transfer Report for ABC Period Device_Code Port Traf_Dir Data_Usage
1Feb2010 - 28Feb2010 SWITCH Fa1_0_1 OUT129.641
1Feb2010 - 28Feb2010 SWITCH Fa1_0_1 IN50.947
1Feb2010 - 28Feb2010 SWITCH Fa1_0_2 OUT19.723
1Feb2010 - 28Feb2010 SWITCH Fa1_0_2 IN11.478

Total Data_Usage: 211.789 ( Need help to get this value... )

Thanks in advance for your help.

In reply to Calculate the Sum of each customer data by roborat

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.