步骤/方法
1、(1)函数分解 len函数返文本字符串中的字符数。 语法:len(text) text是要查找其长度的文本。空格将作为字符进行计数。 mod函数返两数相除的余数。结果的正负号与除数相同。 语法:mod(number,divisor) number为被除数;divisor为除数。 mid函数返文本字符串中从指定位置开始的特定数目的字符,该数目由用户指定。 语法:mid(text,start_num,num_chars) text为包含要提取字符的文本字符串;start_num为文本中要提取的第一个字符的位置。文本中第一个字符的start_num为1,以此类推;num_chars指定希望mid从文本中返字符的个数。
2、(2)实例分析 为了适应上述情况,必须设计一个能够适应两种身份编码的性别计算公式,在d2单元格中输入“=iflen(c2)=15,ifmodmid(c2,15,1),2=1,"男","女",ifmodmid(c2,17,1),2=1,"男","女"”。车后即可在单元格获得该职工的性别,而后只要把公式复制到d3、d4等单元格,即可得到其他职工的性别。
3、为了便于大家了解上述公式的设计思路,下面简单介绍一下它的工作原理:该公式由三个if函数构成,其中“ifmodmid(c2,15,1),2=1,"男","女"”和“ifmodmid(c2,17,1),2=1,"男","女"”作为第一个函数的参数。公式中“len(c2)=15”是一个逻辑判断语句,len函数提取c2等单元格中的字符长度,如果该字符的长度等于15,则执行参数中的第一个if函数,否则就执行第二个if函数。
4、在参数“ifmodmid(c2,15,1),2=1,"男","女"”中。mid函数从c2的指定位置(第15位)提 取1个字符,而mod函数将该字符与2相除,获取两者的余数。如果两者能够除尽,说明提取出来的字符是0(否则就是1)。逻辑条件“modmid(c2,15,1),2=1”不成立,这时就会在d2单元格中填入“女”,反之则会填入“男”。 如果len函数提取的c2等单元格中的字符长度不等于15,则会执行第2个if函数。除了mid函数从c2的指定位置(第17位,即倒数第2位)提取1个字符以外,其他运算过程与上面的介绍相同。