标题:字符串替换求助!
只看楼主
wangguowu
Rank: 2
等 级:论坛游民
帖 子:59
专家分:15
注 册:2012-2-15
结帖率:100%
已结贴  问题点数:20 回复次数:18 
字符串替换求助!
一个字段因列转行,字段内有重复的字符,需要的去除多余的!

原字段内容:(张三、张三、李四)
                 要:(张三、李四)         这样的效果!
水平有限又来麻烦大家了,每次都能得到圆满的解决!首先先谢谢了!
不知用这个CHRTRANC怎么用!
搜索更多相关主题的帖子: 字符串 水平 替换 字段 效果 
2023-04-18 21:52
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:323
帖 子:9621
专家分:26174
注 册: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
等 级:版主
威 望:29
帖 子:484
专家分:1827
注 册: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
来 自:江苏省连云港市
等 级:版主
威 望:323
帖 子:9621
专家分:26174
注 册: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
来 自:江苏省连云港市
等 级:版主
威 望:323
帖 子:9621
专家分:26174
注 册: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
等 级:论坛游民
帖 子:59
专家分:15
注 册:2012-2-15
得分:0 
回复 5楼 sdta
塮谢能用@
2023-04-19 08:14
wangguowu
Rank: 2
等 级:论坛游民
帖 子:59
专家分:15
注 册:2012-2-15
得分:0 
回复 5楼 sdta
将上面的程序
能写通用型针对字段操作替换的函数吗?谢谢!
2023-04-19 21:41
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:323
帖 子:9621
专家分:26174
注 册: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
等 级:论坛游民
帖 子:59
专家分:15
注 册:2012-2-15
得分:0 
回复 8楼 sdta
谢谢明天我试一下@
2023-04-19 23:01
iswith
Rank: 3Rank: 3
等 级:论坛游侠
威 望:3
帖 子:154
专家分:101
注 册:2013-5-14
得分:0 
lcStr = "张三、张三、李四"
?strtran(lcStr , '张三、' , '' )
2023-04-20 07:36



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-511961-1-1.html




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

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