分享
 
 
 

Lotus Notes应用中多页文本的处理

王朝other·作者佚名  2008-05-30
窄屏简体版  字體: |||超大  

日常办公应用中,大量的文档处理不可避免要碰到多页格式文本,而在以文档为主要处理对象的应用程序里,也会碰到这一问题。Lotus Notes的应用程序中,表单是生成文档的模板,如果要在文档中增加表格行,就必须动态改变表单,所以在Lotus Notes中实现格式文档的多页显示仍有其实用意义。

Lotus Domino/Notes是Lotus公司推出的群件系统。通过Lotus Notes的支持,Domino能够为Internet/Intranet用户提供强大的工作流、消息传递、协同计算、信息检索和信息发布等应用。目前,已经有越来越多的公司企业、政府机关使用Lotus Domino/Notes作为协同工作平台,有效地实现了办公自动化。

多页文本的显示问题

在办公应用中,大量的文档处理不可避免要碰到多页格式文本。例如:合同的正本有相应的幅面尺寸规定,一张合同只能输入有限的信息量,因此会碰到一个合同里的交易产品种类数量过多,必须用多页文本显示。在以文档为主要处理对象的应用程序里,也会碰到这一问题,但由于文档在电脑中不受纸面的限制,可以通过对表格增行以得到足够的空间,这样即节省了存储空间,山可不重复存储单据的头信息。

Lotus Notes的应用程序中,表单是生成文档的模板,如果要在文档中增加表格行,就必须动态改变表单。因为Lotus Notes应用程序中的表单是静态的,故动态增删表格行不太方便。另外,考虑到网络普及的今天仍然脱离不了必要的纸面凭证,我们有时仍需打印出大量的文件,所以在Lotus Notes中实现格式文档的多页显示仍有其实用意义。

实现文档的多页显示的前提是:在信息量超过一个表单页面所能显示的信息的时候,能够产生下一页,并将文档的上一页的头信息内容复制到当前页(以一个合同为例,合同的供方及相关信息、需方及相关信息、签订时间、合同号、合同细则都属于头信息,对于一次交易而言,每页合同的这些信息应该相同),同时能增加当前页的页码,并保证一次交易中只有一个惟一标识(通常可用合同号),以确保在浏览上下页时可以打开正确的文档。

实现多页文本的显示

现假设合同表单域名为“Contract”,页码域名为“pageNo”,页数域名为“pages”,合同号域名为“contractNo”。

为了保证填写下一张页面时,能得到上一张页面的值,必须在“Contract”表单的属性里选择“公式继承选定文档的数值”。这里最关键的是要继承合同号、页码和页数信息。为了在新的页面里得到上述信息的正确值,还应再在上述域的缺省值里加上一些公式。在“contractNo”域里的缺省值为:contractNo。可以原封不动地把上一页的合同号拷贝到新的页面,以保证是同一笔交易。在“pageNo”域里的缺省值为:

@if(@environment("isNext")="True";

@do(@environment("isNext";"");pageNo+1);1)。

上面的公式可以辨别当前是第一页还是继续填写的页,其中“pages”域里的缺省值为pageNo。

需要注意的是,虽然继续填写的新页的页数已经增加了,但是并没有改变前面所填页面上的页数值。从符合逻辑的角度来说,前面已填写页面的页数,应该在最后所有页面填完之后才添加上去,所以在新填写的页面未保存时不能将页数统一为新页上的页数。

在“继续填写下一页”按钮按下的时候,执行的操作包括两个:保存并关闭当前页面和打开新的页面。这里采用Lotus Script编写代码,详细代码如下:

Dim workspace As New NotesUIWorkspace

Dim uidoc As NotesUIDocument

Dim session As NotesSession

Set uidoc = workspace.CurrentDocument

If uidoc.editmode=True Then

Call uidoc.save

End If

Call session.SetEnvironmentVar("isNext","True")

'设置用于区分是否下一页的标志

Call uidoc.close

Call workspace.ComposeDocument("","","Contract")

这里在保存的时候还要保证某些信息(如页数)在该笔交易下的所有页面保持同步。这就需要在保存完当前页面后修改其他页面的相应信息。这些操作的代码可以在合同表单的“postsave”事件里写。具体代码如下:

Sub Postsave(Source As Notesuidocument)

Dim session As New notessession

Dim db As notesdatabase

Dim doccol As notesdocumentcollection

Dim datetime As notesdatetime

Dim doc As notesdocument

Set db=session.currentdatabase

formsearch$="form=""Contract""%26amp;%26amp;contractNo="""+source.document.contractN o(0)+""""

Set doccol=db.search(formsearch$,datetime,0)

If doccol.count>0 Then

For i=1 To doccol.count

If i=1 Then

Set doc=doccol.getfirstdocument

Else

Set doc=doccol.getnextdocument(doc)

End If

If doc.universalid<>source.document.universalid Then

doc.pages=source.document.pages(0)

'可以设置其他需要字段的值

Call doc.save(True,False)

'使之与所有页面统一

End If

Next

End If

End Sub

现在,多页文档已经建立好了,还需要对它进行浏览。浏览的方式可以为“上下翻页式”或“到指定页式”,两者原理是一样的,这里以浏览下一页为例加以说明。

首先,创建一个按钮“浏览下一页”,并在按钮的click事件里写以下Lotus Script代码:

Dim workspace As New NotesUIWorkspace

Dim uidoc As NotesUIDocument

Dim session As New NotesSession

Dim db As NotesDatabase

Dim doc As NotesDocument

Dim doccol As NotesDocumentCollection

Dim datetime As Notesdatetime

Set uidoc=workspace.CurrentDocument

Set db=session.currentdatabase

SearchFormula="Form=""Contract""%26amp;%26amp;contractNo="""+uidoc.document.contract

No(0)+"""%26amp;%26amp;p ageNo="""+Cstr(uidoc.document.pageNo(0)+1)+"""" '可以指定任意页

If uidoc.editmode=True Then

Call uidoc.save

End If

Call uidoc.close

Set doccol= db.search(SearchFormula,datetime,0)

Set doc=doccol.getfirstDocument

Set uidoc=workspace.EditDocument( False , doc)

至此,多页文本的创建与浏览已经介绍完了,但是考虑到有删除部分页的可能,所以对于删除指定页的处理也是必需的。删除指定页的基本过程应包括:删除指定页的文档、查找所有该交易的文档、修改这些文档的页数域和修改页码域值大于删除页页码的文档页码域。

以下是实现这一过程的Lotus Script函数代理:

Function deletedocument(doc As notesdocument)

Dim session As New notessession

Dim db As notesdatabase

Dim doccol As notesdocumentcollection

Dim datetime As notesdatetime

Set db=session.currentdatabase

contractno$=doc.contractNo(0)

pageno=doc.pageNo(0)

If doc.remove(0) Then

formsearch="form=""contract""%26amp;%26amp;contractNo=""

"+contractno$+""""

Set doccol=db.search(formsearch$,datetime,0)

For i=1 To doccol.count

If i=1 Then

Set doc=doccol.getfirstdocument

Else

Set doc=doccol.getnextdocument(doc)

End If

doc.pages=doc.pages(0)-1

If doc.pageNo(0)>pageno Then

doc.pageNo=doc.pageNo(0)-1

End If

Call doc.save(True,False)

Next

End If

End Function

以上是在Lotus Notes应用中,对多页文本的一种处理方法,笔者希望读者在实际应用开发中灵活使用。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有