BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
MilenkoAndreas
Calcite | Level 5

Thank you so much Tom! I will try to do that!

Greetings!

Milenko

Cynthia_sas
Diamond | Level 26

HI:
I would use PROC REPORT or PROC PRINT for a report like this. For example, using PROC REPORT, see a similar example using SASHELP.CLASS (where I add up the HEIGHT and WEIGHT instead of COUNT).

Cynthia

ods html file='c:\temp\Total_Line.html';

title 'Total Line for Students Heights';
proc report data=sashelp.class nowd
  style(summary)=Header;
  title 'Proc REPORT';
  column name age sex height weight;
  define name / order;
  define age / order;
  define sex / display;
  define height/ sum;
  define weight / sum;
  rbreak after / summarize;
  compute after  ;
     name='Total';
  endcomp;
run;

ods _all_ close;

MilenkoAndreas
Calcite | Level 5

Cynthia! Thank you so much! But I dont need to do a report.  I want to create another data set, and I will keep working with it, applying functions, etc.In any case, I really appreciate your help.!

Greetings!

Milenko

RW9
Diamond | Level 26 RW9
Diamond | Level 26

Hi,

data have;
  data="data1"; c=2; output;
  data="data2"; c=2; output;
  data="data3"; c=1; output;
run;

proc sql;
  create table WANT as
  select  *
  from    HAVE
  union all
  select  "Total",
          sum(C) as C
  from    HAVE;
quit;

yeshwanth
Fluorite | Level 6

One simple approach:

data y1;
input data $ count;
cards;
d1 100
d2 500
d3 800
d4 60
;
quit;

proc sql;
create table y2 as
select "total" as data, sum(count) as count
from y1;
quit;

data final;
set y1 y2;
run;

Hope this helps !!

art297
Opal | Level 21

Milenko,

This is in response to the question you asked .  His code, with explanations, is shown below. The explanations are shown within comments, so that they don't have to be removed in order for the program to run:

data want;

  set have end=last; /*use have to create new file called want and creating an extra temporary variable

                                  called 'end' that will only have a value of 1 when the last record from have is read */

  _ct+count; /*create a variable called _c1 that, by the time the last record is read, will contain the sum of

                     all values of count*/

  output; /* output the record */

  if last then do; /*ONLY do the following after the last record has been output */

    var='Total'; /*Change the value of var to be Total*/

    Count=_CT; /* Change the value of Count to equal the value of _CT */

    output; /* Output the Total record */

  end;

  drop _ct; /* Drop _ct from the list of variables that will be output */

run;

Haikuo
Onyx | Level 15

Thanks, Art! And my apologize to OP. I haven't realized being asked a follow-up question until Art mentioned my name. The bottom line is that there is no way for me to do a better job than Art anyway , so OP, consider yourself lucky.Smiley Happy

MilenkoAndreas
Calcite | Level 5

Arthur! Thank you so much! sorry for the late reply, but im not always working on SAS, your explanation was very helpful, although i dont completely understood it, but it worked perfect!

if instead of _ct+count ..i use _ct+sum ..or _ct+ any other function...would it work? What is the logic of using the operator + with a column?

and i dont understand very well what do you mean with "that will only have a value of 1 when the last record from have is read "

Anyway...you have been very helpful...I really appreciate !

Greetings,

Milenko

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 22 replies
  • 53746 views
  • 14 likes
  • 8 in conversation