MS Word field formulas: creating arrays and computing dates using excel compatible formulas
Emin Gabrielyan
2008-09-16
Switzernet
MS Word field formulas: creating arrays and computing dates using excel compatible formulas
Compact formulas for computing the date of the previous day
Mysteries of Word field formulas when using variable names ending with a number
Making arrays by storing the names of variables in a variable:
Computing the first days of a number of past months
We already presented field formulas for computing the previous day of any given date [080904-word-field-date-calc], [ch1], [ch2], [080904-word-field-process-dates], [ch1], [ch2]. The computation is done with three simple formulas for computing the year =aay-and(aam=1,aad=1), the month =mod(aam-1+12-(aad=1),12)+1, and the day =if(aad>1,aad-1,if(bbm=2,if(mod(bby,4)=0,29,28),30+mod(bbm+(bbm>=8),2))) values of the previous day. The formulas are Excel compatible (we use functions mod, and, and if). Joined is an excel file using exactly the same formulas [xls]. The formulas can be copy-pasted back and forth between ms-word and excel. An operational web version of the excel sheet is also provided [htm]. Change the input cell values then use tab key and shift-tab to switch between input cells and to update the output cells. Below is the screenshot of the toggled field codes followed by the field codes themselves:
[doc]
Setting the year, month, and day values of the input date:
Computing the year, month, and day values of the previous day:
The input date and its previous date are below (in yyyy-MM-dd format):
2008-3-1
2008-2-29
The input date and its previous date are below (in “dddd, MMMM dd, yyyy” format):
Saturday, March 01, 2008
Friday, February 29, 2008
The version presented in this section is more compact and accurate than the versions presented in previous documents [080904-word-field-date-calc], [ch1], [ch2], [080904-word-field-process-dates], [ch1], [ch2]. The leap year computation is not complete when it concerns the century changes.
Do not use digits at the end of variable names when using field formulas. In formula {=a1+1} the reference to variable “a1” is replaced by 0, while the reference to variable “a1val” is treated as expected {=a1val+1}. Curved brackets {} replace the variables with their values and may avoid errors if a variable name ending with a number must be used at any cost {={a1}+1}.
Below is the screenshot of the toggled field codes followed by the field codes themselves:
[doc]
Setting the value of a1val to 100:
Setting the value of a1 to 200:
Computation with a1val: 101
Computation with {a1val}: 101
Computation with a1: 1
Computation with {a1}: 201
The field codes demonstrate that the result of {=a1+1} formula is 1 instead of 101. Though two variables, a1 and a1val, are defined as expected:
Variable names can be computed on the fly in the assignment operation {set var val} and when accessing and displaying numerical values with formulas {=var}. Variables storing variable name is an alternative to arrays for working with indexed numerical values. Below is the screenshot of the toggled field codes followed by the field codes themselves:
[doc]
Setting i to 0
Setting v to 1
Setting i to 0
Variable a0val contains 1
Variable a1val contains 3
As expected, after updating the field codes you can see the defined variables (bookmarks):
To see bookmarks press Alt-I-K. You have to delete all bookmarks, select and update the field codes, and then view the bookmarks again in order to see only those variables which are defined by the updated field codes.
The substitution of the variable name by another variable containing that name does work only for numerical formulas {=…}. Variable name cannot be substituted within the field operator {var}.
Below is the screenshot of the toggled field codes for computing the dates of first days of past five months. The screenshot is followed by the field codes themselves:
[doc]
old0m: 1.4.2008
old1m: 1.3.2008
old2m: 1.2.2008
old3m: 1.1.2008
old4m: 1.12.2007
old5m: 1.11.2007
http://office.microsoft.com/en-us/word/HP051862181033.aspx
http://office.microsoft.com/en-us/word/HP051861861033.aspx
http://switzernet.com/public/080902-layout-red-slip/
http://unappel.ch/public/080902-layout-red-slip/
http://www.addbalance.com/word/datefields1.htm
http://www.addbalance.com/word/datefields2.htm
http://forums.techguy.org/business-applications/265813-creating-field-word-excel-formula.html
Using MS Word field formulas to compute the previous date of a given input date (without merging with an excel file):
http://switzernet.com/public/080904-word-field-date-calc/
http://unappel.ch/public/080904-word-field-date-calc/
http://google.ch/search?q=Creating+a+field+in+Word+with+an+Excel+formula
http://google.ch/search?q=word+field+formulas+for+dates
Computing previous days’ values of a set of input dates with MS Word field formulas:
http://switzernet.com/public/080904-word-field-process-dates/
http://unappel.ch/public/080904-word-field-process-dates/
MS Word field formulas: creating arrays and computing dates using excel compatible formulas (this document):
http://switzernet.com/public/080916-ms-word-field-formulas/
http://unappel.ch/public/080916-ms-word-field-formulas/
Generating overdue payment letters:
http://switzernet.com/company/080915-howto-word-formulas-reminders/
Leap year’s complete formula:
http://en.wikipedia.org/wiki/Leap_year
* * *
Copyright © 2008 Switzernet