| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1065 人关注过本帖
标题:字符串替换求助!
只看楼主 加入收藏
wangguowu
Rank: 2
等 级:论坛游民
帖 子:73
专家分:18
注 册:2012-2-15
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:18 
字符串替换求助!
一个字段因列转行,字段内有重复的字符,需要的去除多余的!

原字段内容:(张三、张三、李四)
                 要:(张三、李四)         这样的效果!
水平有限又来麻烦大家了,每次都能得到圆满的解决!首先先谢谢了!
不知用这个CHRTRANC怎么用!
搜索更多相关主题的帖子: 字符串 水平 替换 字段 效果 
2023-04-18 21:52
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:335
帖 子:9841
专家分:27213
注 册:2012-2-5
收藏
得分:0 
lcStr = "张三、张三、李四"
ALINES(laStr, lcStr, "、")
lcStr = SPACE(0)
FOR ln = 1 TO ALEN(laStr, 1)
    IF NOT laStr[ln] $ lcStr
        lcStr = lcStr + "、" + laStr[ln]
    ENDIF
ENDFOR
? SUBSTR(lcStr, 3)

坚守VFP最后的阵地
2023-04-18 23:05
csyx
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:火星
等 级:版主
威 望:37
帖 子:707
专家分:2833
注 册:2018-3-13
收藏
得分:0 
以下是引用sdta在2023-4-18 23:05:43的发言:

lcStr = "张三、张三、李四"
ALINES(laStr, lcStr, "、")
lcStr = SPACE(0)
FOR ln = 1 TO ALEN(laStr, 1)
    IF NOT laStr[ln] $ lcStr
        lcStr = lcStr + "、" + laStr[ln]
    ENDIF
ENDFOR
? SUBSTR(lcStr, 3)

不带分隔符来判断包含是不行的,假设 lcStr = "张三丰、张三、张三、李四",会得到什么?

这家伙很懒,啥也没留下
2023-04-18 23:11
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:335
帖 子:9841
专家分:27213
注 册:2012-2-5
收藏
得分:0 
以下是引用csyx在2023-4-18 23:11:36的发言:


不带分隔符来判断包含是不行的,假设 lcStr = "张三丰、张三、张三、李四",会得到什么?

现在想想带分隔符也没用。
lcStr = "王张三、张三、张三、李四"
暂时的方法是用临时表处理了。

坚守VFP最后的阵地
2023-04-18 23:38
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:335
帖 子:9841
专家分:27213
注 册:2012-2-5
收藏
得分:20 
lcStr = "张三、张三、李四"
ALINES(laStr, lcStr, "、")
DIMENSION laStr[ALEN(laStr, 1), 1]
CREATE CURSOR tt (xm c(10))
INSERT INTO tt FROM ARRAY laStr
SELECT DISTINCT xm FROM tt INTO ARRAY laStr
lcStr = SPACE(0)
FOR ln = 1 TO ALEN(laStr, 1)
    lcStr = lcStr + "、" + ALLTRIM(laStr[ln])
ENDFOR
? SUBSTR(lcStr, 3)

坚守VFP最后的阵地
2023-04-18 23:44
wangguowu
Rank: 2
等 级:论坛游民
帖 子:73
专家分:18
注 册:2012-2-15
收藏
得分:0 
回复 5楼 sdta
塮谢能用@
2023-04-19 08:14
wangguowu
Rank: 2
等 级:论坛游民
帖 子:73
专家分:18
注 册:2012-2-15
收藏
得分:0 
回复 5楼 sdta
将上面的程序
能写通用型针对字段操作替换的函数吗?谢谢!
2023-04-19 21:41
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:335
帖 子:9841
专家分:27213
注 册:2012-2-5
收藏
得分:0 
是不是这个意思
程序代码:
CLEAR 
CREATE CURSOR test (xm c(20))
INSERT INTO test VALUES ("张三、张三、李四")
INSERT INTO test VALUES ("刘三、李四、刘三")
INSERT INTO test VALUES ("李四江、刘三、李四、刘三")
SCAN 
    ? fwr(xm)
ENDSCAN
FUNCTION fwr(lcStr)
    ALINES(laStr, lcStr, 4+1, "、")
    DIMENSION laStr[ALEN(laStr, 1), 1]
    CREATE CURSOR tt (xm c(10))
    INSERT INTO tt FROM ARRAY laStr
    SELECT DISTINCT xm FROM tt INTO ARRAY laStr
    lcStr = SPACE(0)
    FOR ln = 1 TO ALEN(laStr, 1)
        lcStr = lcStr + "、" + ALLTRIM(laStr[ln])
    ENDFOR
    RETURN SUBSTR(lcStr, 3)
ENDFUNC 
RETURN 

坚守VFP最后的阵地
2023-04-19 22:21
wangguowu
Rank: 2
等 级:论坛游民
帖 子:73
专家分:18
注 册:2012-2-15
收藏
得分:0 
回复 8楼 sdta
谢谢明天我试一下@
2023-04-19 23:01
iswith
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:5
帖 子:447
专家分:582
注 册:2013-5-14
收藏
得分:0 
lcStr = "张三、张三、李四"
?strtran(lcStr , '张三、' , '' )
2023-04-20 07:36
快速回复:字符串替换求助!
数据加载中...
 
   



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

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