宏替换的应用。
我们来学习foxpro的一个十分强大而又非常容易掌握的功能:宏替换。就从名字上看来这不是个容易对付的家伙,在开始讲宏替换之前,让我们先来看一看这样的一个例子:
假设我们有两个表,1997级学生成绩表(和1999级学生成绩表(这时我们要求用户在浏览表之前先输入年份,以便我们来打开用户指定年度的学生成绩表。也许你会说:“这太容易了,俺会呀”然后给出下面的方案:
先用一个文本框来接收用户的输入的年份,然后调用下面的**来打开表:
do case
case = 1997'
use ‘'
case = 1999'
use ''
endcase
brow不错,您的这段**表面上是达到了要求。但是它存在着几个问题:
问题1:当学生成绩表很少时(如:上例只有和两个表),用上面的**可以轻松摆平。但是如果表很多时,假设有十个年度的学生成绩表(这下惨了,**就会变成下面的样子:
do case
case = 1980'
use ''
case = 1981'
use ''
case = 1982'
use ''
case = 1982'
use ''
为了节省你的网费,我的纸,我就不继续打了,我想您应该明白哪些麻子……代表什么了吧……
endcase
这样一来**非常的冗长。但这还不是最糟的,更惨的在下面(天啊~~)
问题2:当随着学生的升学,用来保存学生每年学习成绩的表也会动态的增加,这时上面的**就完全失去了做用。用上面的**无法预先知道到底会有多少个学生成绩表,也就不可能事先设n个case来判断年份了。
宏替换:“不要担心,少要害怕,俺宏替换来也”。宏替换是foxpro为我们提供的一项强大的功能。它的运算符是“&”作用就是提取字符串的现值,返回值是字符串常数。
看到这里您的第一反应可能会是:“what?什么乱七八糟的,你说的是什么意思?”。
别忙,接着往下看您就明白了。下面就让我们用宏替换功能来完成上面例子的功能,是又好又省事儿,包您满意。这次假设我们有20个表(一分别存放每一年的学生成绩,放心我们绝对不会用20个case的:
c_year = 用变量c_year来接收用户输入的年份。
use &c_year
上面这一句利用宏替换来根据c_year的值来找打开对应的表,等价于。
use ‘只不过引号的表名是随c_year的值而变罢了。
brow搞定,收工。嘿。。。怎么样,是不是又省时又省力呀?
再看下面的例子:
a='b'b='庄稼'
a &&显示的结果是“b”
&a &&显示的结果是“庄稼”
也就是说宏替换将当前变量的值作为真正需要的变量,并返回这个变量的值。
vfp 的很多命令的某些地方不能使用变量,比如上面的 use 命令,你不能写成:
a=''use a
这样就成了打开 a 这个表,这时就必须用宏替换,use &a
类似的还有当 locate for 后面跟的条件不是固定的,你的程序可以允许操作者选择不同的字段来查询,可能是:
姓名=..也可能是:
**=..你不能直接把 for 后面的内容整个作为一个变量,这时宏替换也可以起作用,你可以把条件整个放入一个变量,比如字段名放在一个变量中 zdm,要查的内容放在 nr:
tj=zdm+"'nr+"'
locate for &tj
如果这时 zdm='姓名',nr='庄稼',这就相当于:
locate for 姓名='庄稼'
那么只要 tj 的内容是个正确的逻辑表达示,不论是什么内容都可以运行,这将给编程带来很大方便。
多学一招你甚至可以把整条语句放入一个变量:
tj="locate for "+zdm+"'nr+"'tj酷吧!
注意值得注意的是,宏替换&不能递归的引用自已。比如下面的用法就是错误的:
store “&zl” to zl
&zl赋值语句与宏替换巧妙地组合,能实行灵活的查询和程序控制,提高程序通用性,使程序更加简练,运行效率更高,龙其在处理一些不确定对象时,宏替换将扮演非常重要角色。
最后补充一点,虽然宏替换功能强大,但是也不要太频繁使用,正是由于宏替换灵活性,使得它执行时要进行一些转换,如果太多的使用宏替换可能会影响程序的性能。
所以在一些不是必须的场合下,尽量避免使用宏替换 ,就象好吃的东西吃得多了也会起腻一样,宏替换用的太多也会使你的程序不舒服的。
Excel高级使用技巧宏的应用
excel高级使用技巧 宏的应用。宏是一个指令集,用来告诉excel来完成用户指定的动作。宏类似于计算机程序,但是它是完全运行于excel之中的,我们可以使用宏来完成枯燥的 频繁的重复性工作。宏完成动作的速度比用户自己做要快得多。例如,我们可以创建一个宏,用来在工作表的每一行上输入一组日期,并在每一...
不同材料的替换作业
异种材料的替换作业,在材料替换的前后,我们利用各种材料的溶融粘度的差异来进行作业,料筒的温度控制应预先着手决定。对一般性的热可塑性材料,温度高就客易粘在金属面上,而温度低就不易粘在金属面上,替换作业就是利用材料的这个性质,让想替换掉 想挤出 的材料粘在热的加热料筒内壁上,然后对冷的螺杆供给粘度高的材...
不同材料的替换作业
异种材料的替换作业,在材料替换的前后,我们利用各种材料的溶融粘度的差异来进行作业,料筒的温度控制应预先着手决定。对一般性的热可塑性材料,温度高就客易粘在金属面上,而温度低就不易粘在金属面上,替换作业就是利用材料的这个性质,让想替换掉 想挤出 的材料粘在热的加热料筒内壁上,然后对冷的螺杆供给粘度高的材...