Solved

How to pass data from detail section as input of formula in Crystal Reports

Posted on 2014-09-16
9
294 Views
Last Modified: 2014-09-17
For Example :
Crystal Reports "Detail Section A - Sorted By Customer ID 001" - data show as below

ITEM NAME   SHELF NO    QTY

Item A             1                   12,000
item B             2                   14,000
item C             2                   10,000
item D             3                   12,000

Crystal Reports "Detail Section B - Sorted By Customer ID 002" - data show as below

ITEM NAME   SHELF NO    QTY

Item E             4                   16,000
item F             4                   10,000
item G            5                   18,000
item H            6                   14,000


How do I count the percentage of QTY by SHELF NO for each Customer ID?
The results look like :

Customer ID 001
           SHELF NO 1 : 25% ((12,000) / (12,000 + 14,000 + 10,000 + 12,000))
           SHELF NO 2 : 50% ((14,000 + 10,000) / (12,000 + 14,000 + 10,000 + 12,000))
           SHELF NO 3 : 25%
Customer ID 002
           SHELF NO 4 : 44.8276%
           SHELF NO 5 : 31.0345%
           SHELF NO 6 : 24.1379%

No need to get report like this - just like to know how to pass SHELF NO and QTY into formula or any other way also can get the same result.
Please help
0
Comment
Question by:City_Of_Industry
  • 3
  • 3
  • 2
  • +1
9 Comments
 
LVL 39

Expert Comment

by:Kyle Abrahams
Comment Utility
From:
http://devshed.us/Blogs/tabid/227/EntryId/31/Percentage-of-Total-field-in-a-Crystal-report.aspx

{myDatasource.QTY } % Sum ({myDatasource.QTY})

Open in new window


I would assume this could also go in the group footer.
0
 

Author Comment

by:City_Of_Industry
Comment Utility
To be more specific - I need all those number of percentage as variables and use them as one element of formula in other sub-report's detail section
0
 
LVL 100

Expert Comment

by:mlmcc
Comment Utility
To accomplish this you need to

1.  Group by the Customer ID
2.  Group by the Shelf No

Shelf Percent is calculated with

Sum({Qty},{Shelf Number}) / Sum({Qty}, {Customer ID})

Put the formula in the Shelf Group Header or Footer

mlmcc
0
 
LVL 34

Expert Comment

by:James0628
Comment Utility
... and use them as one element of formula in other sub-report's detail section
You want to pass these values to a subreport?

 Assuming that the answer is "Yes" ...

 Where is that "other" subreport?

 Since you said "other" subreport, where are the quantity values that you're using to calculate those %'s located?  Are they in the main report or in a different subreport?

 The answers to those questions may determine the answer to the following question:
 Are you just trying to pass the values (%, etc.) for one shelf at a time to the subreport?
 Or are you trying to pass the values for multiple shelves, maybe all of them, to the subreport at the same time?

 James
0
Do You Know the 4 Main Threat Actor Types?

Do you know the main threat actor types? Most attackers fall into one of four categories, each with their own favored tactics, techniques, and procedures.

 

Author Comment

by:City_Of_Industry
Comment Utility
Thank you James,

                 I was trying to pass all percentage (SHELF NO 1 - 25%, SHELF NO 2 - 50%, ...) to another subreport in same main report (For example : This main report contains five subreports : subreport 1, subreport 2, ... subreport 5 (they are from different tables)

                 Subreport 1 - have all ITEM NAME, SHELF NO and QTY information - Can I pass all percentage data - calculated from subreport 1 (or all ITEM NAME, SHLEF NO and QTY) data to subreport 5 in same main report? (I tried but only get the first row of data - Item A from subreport 1 Detail Section)
0
 
LVL 100

Accepted Solution

by:
mlmcc earned 400 total points
Comment Utility
To really be able to help with this we probably need to see the report file so we can understand where the subreports are and the data available to them.

How are you passing data that you only get 1 row?

Are you SHARING an array variable?

The basic method of takes 3 formulas

Main Report - I generally put this in the report header

WhilePringintRecords;
Shared NumberVar Array Percents;
''

Open in new window


In the subreport you would build the array

WhilePringintRecords;
Shared NumberVar Array Percents;
Local NumberVar Index;

ReDim Preserve Percents[4];
For Index := 1 to 4 do
   Percents[Index] := Some Formula;
''

Open in new window


In the other subreport (must be in a section after the subreport that fills the data)

WhilePringintRecords;
Shared NumberVar Array Percents;
 CODE TO USE THE ARRAY OF VALUES

Open in new window


mlmcc
0
 
LVL 34

Assisted Solution

by:James0628
James0628 earned 100 total points
Comment Utility
If you want to pass multiple values for multiple fields (eg. SHELF NO and QTY), then you may need multiple arrays.

 A CR array can have up to 1000 elements, so if SHELF NO will always be 1000 or less, then you could use that as the index for the array(s).  The data for shelf 1 goes in the first element in the array(s), the data for shelf 12 goes in the 12th element, and so on.

 If shelf # could be > 1000, then you'd need to store each shelf # in one array, and store the quantity for that shelf in the corresponding element in another array.  The first shelf # and quantity go in the first elements of the arrays, the second set of values goes in the second elements, and so on.


 Your last post indicated that you also want to pass ITEM NAME, but in your first post, you seem to be ignoring that for your totals.  For example, you have shelf # 2 with "item B" and "item C", and you just combined those for the total.  If you want to pass ITEM NAME too, that will complicate things.

 James
0
 

Author Closing Comment

by:City_Of_Industry
Comment Utility
Thank you James and Michael

As non-programmer and in one man Dept. , I spent lots of time to googling and figure out the solution (Array) according to your guidance. Currently I can pass whole set of data from one subreport to another subreport as elements of formula in there.
I learned a lot from both of your answer above, I really appreciate your help.
Thank you again
0
 
LVL 34

Expert Comment

by:James0628
Comment Utility
You're welcome.  Glad I could help.

 James
0

Featured Post

IT, Stop Being Called Into Every Meeting

Highfive is so simple that setting up every meeting room takes just minutes and every employee will be able to start or join a call from any room with ease. Never be called into a meeting just to get it started again. This is how video conferencing should work!

Join & Write a Comment

I hate sub reports and always consider them the last resort in any reporting solution.  The negative effect on performance and maintainability is just not worth the easy ride they give the report writer.  Nine times out of ten reporting requirements…
Hello everyone, Hope you find this as helpful as we did. We have on the company I work for an application built in Delphi V with Crystal Reports 8. We all know that Crystal & Delphi can be temperamental sometimes and the worst thing is, nearly…
It is a freely distributed piece of software for such tasks as photo retouching, image composition and image authoring. It works on many operating systems, in many languages.
Here's a very brief overview of the methods PRTG Network Monitor (https://www.paessler.com/prtg) offers for monitoring bandwidth, to help you decide which methods you´d like to investigate in more detail.  The methods are covered in more detail in o…

743 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

19 Experts available now in Live!

Get 1:1 Help Now