modify()函数的用法 modify函数

modify()函数的用法

dw1.modify(modstring)


一、功能:使用字符串中定义的操作修改数据窗口控件 其中:modstring:string类型,其值定义修改数据窗口的各种操作。
返回值:string .成功时返回空字符串(“”),发生错误时返回一条出错消息。形式:"line n column nincorrect syntax"(指明哪行哪列错了)


 可以应用于:a.修改数据窗口中各种对象的颜色、标题、文本等。
       b.修改数据窗口中不同表的更新状态,以便让应用程序一次可以更新多个表
       c.修改数据窗口对象中sql select语句中的where子句
       d.改变retrieve only as needed(按需检索数据)状态(对应于数据窗口对象的

retrieve.asneeded属性,

modity()中引用该函数为:object.datawindow.retrieve.asneeded)
e.改变数据窗口对象的数据源
       f.控制打印预览显示模式。
       g.在数据窗口对象中增加和删除对象


二、modify()函数中使用的表达式

当为数据窗口对象的某个属性指定一个表达式时,

其表达式的格式格式:defaultvalue~tDataWindowpainterexpression

其中datawindowpainterexpression是数据窗口画笔表达式。


如:modstring="empid.color='16777215~tIF(emp_status=~~'A~~',255,16777215)'"

dw1.modify(modstring)

对于empid列来说,当emp_status列的值为A时,empid列的数据显示为红色,否则为白色。


如:rtn=dw_1.modify("emid.font.italic=0oval_1.backgroud.mode=0oval_1.backgroup.color=255")

一次修改了多个对象的属性
如:dw1.modify("objectname.backgroup.mode='<0,1>'")

dw1.modify("objectname.backgroup.color='long'")

要将背景高为不透明(opaque)才能看到背景颜色。


如:dw1.modify("depid.color='0~t"+"if(depid=200,65380,if(dipid=100,255,0))"')

当depid=200时,其值显示为绿色,等于100时为红色,其它值为黑色。


如:stringmod_string,err

longcolor1,clor2,color3,default_color
err=dw1.modify("salary.backgroup.mode=0")
iferr<>"" thenreturn


下面是构造modstring,如果salary<10000,则其背景高为红色; 20000<如果>=10000设为蓝色,30000<如果>20000 设为绿色;其它为的白色。

 color1=255 //红色

  color2=16711680 //蓝色

  color3=65280 //绿色

 default_color=1677215//白色
modstring="salary.backgroup.color="'+string(default_color)+"~tIF(salary<10000,"+string(color1)+",if(salary<20000,"+string(color2)+",if(salary<30000,"+string(color3)+","string(default_color)+")))'"
err=dw1.modify(modstring)
if err<>"" then
messagebox("tip",出错位置为:"+err)
return
end if


如:dw1.modify("dep_t.text='部门'") //把dw1中文本对象dep_t的标题改为”部门“
如:dw1.modify("dep_t.text='无~t"+"if(depid>201,~'营销部~',~'财务部~')'")

如果depid>201其标题为”营销部“,否则为”财务部“)


如: original_select=dw1.describe("datawindow.table.select")
mod_string="datawindow.table.select="'+original_select+where_clause+""'
rc=dw1.modify(mod_string)
if rc=""then
dw1.retrieve()
else
messagebox("tip","this error is"+rc)
end if


如:stringrc,mod_string,name_str="张飞"integer dept_num=100
dw1.modify("datawindow.table.select="")//去掉数据窗口中的Select语句
modify()函数的用法 modify函数
   mod_string="datawindow.table.procedure='1 executedbo.emp_arg2;1@dept_id_arg=:num_arg1,@lname_arg=:str_arg1"' //将数据窗口的procedure属性设置为所需的存储过程
    rc=dw1.modify(mod_string)
if rc="" then
dw1.retrive(dept_num,name_str)
else
messagebox("tip","fail is "+rc)
endif//////////////////////
如:dw1.modify("destroy logo") //删除dw1中的位图logo


如:dw1.modify("destroy column salary")//删除数据窗口dw1中的列对象salary,同时从缓冲区中删除该列的 数据(这是column的作用)


如:modstring='create bitmap(band=footer x="37" y="12' height="101"width="1509"filename="c:p1.bmp"border="0" name=bmp1)'
dw1.modify(modstring)//在数据窗口dw1的第一个分组的组标题同区增加一个名为p1位图对象。

例如

  1、改变detail区的高度:dw_1.Modify("DataWindow.detail.Height=200")
  2、对标题栏文本的更改(文本名为dept_name_t):dw_1.modify("dept_name_t.text ='单位名称'")
  3、增加计算域:假设一grid型的数据窗口,其中有个字段为部门号dept_id,我们要增加一个统计部门数的计算域count(dept_idfor all):
  string ls_modrow
  dw_1.Modify("DataWindow.summary.Height=64")
  ls_modrow = 'Create compute(band=summary font.charset="0"font.face="MS Sans Serif" font.family="2" font.height="-8"font.pitch="2" font.weight="400" background.mode="1"background.color="536870912" color="0" x="9" y="4" height="52"width="297" format="[general]" expression="count(dept_id for all)"alignment="1" border="0" crosstab.repeat=no )~r~n'
  dw_1.modify( ls_modrow )
  4、以下程序段让grid数据窗口中网格线不见,并在detail区增加加一条线
  string ls_line
  DW_1.Modify("DataWindow.Grid.Lines='1' ")
  dw_1.Modify("DataWindow.detail.Height=332")
  ls_line = 'Create line(band=detail background.mode="2"background.color="16777215" pen. pen.width="5"pen.color="0" x1="37" y1="320" x2="1458" y2="316" )~r~n'
  dw_1.modify( ls_line )
  象这种数据窗口动态增加控件的方法,也可以先在数据窗口画板中手工加上去,倒成sytnax后,查看其语法,再反写回去即可。

  

爱华网本文地址 » http://www.aihuau.com/a/25101016/323571.html

更多阅读

EXCEL表中LEFT和RIGHT函数的用法 left和right函数

在用EXCEL表中的时候,懂得一些常用的函数,会给你的工作带来很大便利。就像上次偶然的机会,听同事说道LEFT和RIGHT函数的用法,还挺有用的。像导出的财务数据,日期的格式都是2010-01-01,但是如果你只需要年月,不需要日期,你可以插入另外一列,适用

SetTimer函数的用法 c settimer用法

SetTimer函数的用法VS2008Ontimer函数在CDialogBar类中不能响应解决方案:如果是手工加的wm_timer消息,那就要检查一下BEGIN_MESSAGE_MAP(...Dlg, CDialog),END_MESSAGE_MAP()ON_WM_TIMER()宏之间有没有ON_WM_TIMER()了,没有的要添

Excel统计函数COUNTIF的用法及实例 vb随机函数用法和实例

[转自]★笨笨☆ http://blog.sina.com.cn/pengjichang一:首先介绍COUNTIF函数的用法英文通用格式是:COUNTIF(range,criteria)中文通用格式是:COUNTIF(数据区域,条件表达式)1、返加包含值12的单元格数量=COUNTIF(range,12)2、返回包含负值的

声明:《modify()函数的用法 modify函数》为网友只知念你分享!如侵犯到您的合法权益请联系我们删除