| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1041 人关注过本帖
标题:关于长数字的替换填充
取消只看楼主 加入收藏
liuhaijun
Rank: 2
等 级:论坛游民
威 望:1
帖 子:176
专家分:45
注 册:2008-12-27
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:1 
关于长数字的替换填充
学生学号(XH)长度是18 字符型 如:305200909034500001  前13位固定不变,后5位递增。
我想用repl 的方法填充。
先做一个表单 ,加一个文本框Text1),按钮下的代码是:
set talk off   
km8=alltrim(thisform.text1.value)  
gg=val(km8)
repl all xh with alltrim(str((recno()+gg-1),18))
thisform.release

注:km8 和gg 均为全局变量,km8 用来接收text1 所输入的起始号。

问题:当起始号小于等于16位时,正常替换;当起始号大于等于17位时,个位均变成 0 ,不能正常替换。
      请问如何处理,来替换18位的学号(XH)?
搜索更多相关主题的帖子: 数字 
2009-10-06 00:17
liuhaijun
Rank: 2
等 级:论坛游民
威 望:1
帖 子:176
专家分:45
注 册:2008-12-27
收藏
得分:0 
非常感谢二位老师的指点,可以正常填写充了。代码如下:
set talk off      
km8=left(thisform.text1.value,13)     
repl all xh with km8 +padl(recno(),5,"0")
thisform.release   

以上代码填充的结果是从1开始填充,如果起始码不是1
使用sywzs老师给的代码:
set talk off      
gg=val(subs(km8,14))   
km8=left(thisform.text1.value,13)     
repl all xh with km8 +padl(recn()-1+gg,5,"0")   
thisform.release   

会弹出“函数参数的值、类型或数目无效。”的提示。
我用的是VF6.0版。
2009-10-06 12:52
快速回复:关于长数字的替换填充
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.014830 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved