Calculations based on .includes
Copy link to clipboard
Copied
Hi all,
Trying to figure out the custom calculation script to be able to add multiple values of different form fields if a form field includes a value above 300. For context, I am trying to sum the number of upper division credits, (courses at 300 level or above,) for a form that I use to meet with students. In the attached file, I would love for "UD Credits" to add the value of "a" if "Fall 1" includes in a string a value above 300, such as MATH 321. I would then need to add the respective values of "aa," "aaa," "aaaa" and so on based on their respective left form fields.
Sorry to ask this question! I'm very, very new at javascript and I've tried to experiment with the script by using boolean logic, .includes, etc. but I'm just not able to make anything work!
Copy link to clipboard
Copied
There are several parts to creating such a script.
1) the script needs to draw a relationship between the "Fall" and the "a" fields. This is usually done with field naming, although you could also create an array of fields as well.
2) The script need to be able to identify the number part of the data. Use RegExp pattern matching for this.
Here's an article:https://acrobatusers.com/tutorials/text-matching-regular-expressions/
3) The method: Loop over the list of "Fall" names, if pattern is found, and is > 300, the add associated value;
Use the Acrobat JavaScript Reference early and often
Copy link to clipboard
Copied
Thank you so much for the quick response! Sorry to ask, but do you have an example of the script you are describing? I'm reading over the RegExp article you've listed and I'm not sure how I might link it to the >300 script to write... Thanks again! I really appreciate it!
Copy link to clipboard
Copied
this regular expression will identify 3 numbers by themselves.
var rg3Digit = /\b(\d{3})\b/;
The \b part means word boundary. So this would not form for something like "Something 345a". For that you would need to modify the RegExp.
Notice that the digits are grouped so they can be extracted for use with the comparison.
You'll need to read up on JavaScript Regular Expressions to use it in a script.
Use the Acrobat JavaScript Reference early and often
Copy link to clipboard
Copied
Thanks again. From what I'm reading about regular expressions, I'm just confused as to how to implement the method you've described in your first reply. I'm pretty sure this is just me not knowing JavaScript, but what am I to do with the var rg3Digit = (/\b(\d{3})\b/); script?
My first instinct is to do the following:
var fall1 = "Fall 1"
var rg3Digit = fall1.includes(/\b(\d{3})\b/);
which should then output true
and then I would also have a script where
if (rg3Digit = true)
var udCredits = "a"
but then I don't necessarily know how to sum this for all of the Fall 1-5 field forms. I'm sorry I'm really inept at scripting!
Copy link to clipboard
Copied
So in the article I've linked above it shows how to use the regular expression "test()" function to find pattern matches. It's important to read and test out the material. You should be doing this from the Acobat JavaScript Console Widow. There's a tutorial here:
https://www.pdfscripting.com/public/Free_Videos.cfm#JSIntro
What the article doesn't show is how to group pattern elements can be extracted. Like this:
if(rg3Digit.test(cFallValue) && (Number(RegExp.$1) > 300))
nSum += ... value from associated field ...;
Use the Acrobat JavaScript Reference early and often
Copy link to clipboard
Copied
Hi Thom,
Thank you so much for keeping with me! So what I have so far then is:
var rg3Digit = /\b(\d{3})\b/;
var cFallValue = this.getField ("Fall 1");
if(rg3Digit.test(cFallValue) && (Number(RegExp.$1) > 300));
nSum += this.getField ("a");
which then says via JavaScript Console Window that nSum is undefined which I'm not too sure how to fix. I figure I'll learn how to do it with just one example as I try to figure out how to do it en masse unless it's nominally easier to do it in bulk... When I run app.alert for the output, it works though!
Copy link to clipboard
Copied
The nSum variable need to be defined and initialized before it can be used.
var nSum = 0;
Now all you need to do is put this in a loop that tests and adds all the rows.
Use the Acrobat JavaScript Reference early and often
Copy link to clipboard
Copied
I've tried adding the var nSum = 0; before but no matter where I place it, it pops up as undefined?
var nSum = 0;
var rg3Digit = /\b(\d{3})\b/;
var cFallValue = this.getField ("Fall 1");
if(rg3Digit.test(cFallValue) && (Number(RegExp.$1) > 300));
nSum += this.getField ("a");
ReferenceError: nSum is not defined 1:Console:Exec undefined