注册 登录
编程论坛 VFP论坛

求解字符对比的问题,同样的数据不同的结果(数据已提供)

hjlali 发布于 2021-08-22 11:33, 1997 次点击
两个表f1和y1.都包含了lxfs字段,字段长度都是50
? SET('ansi')  && off
? SET('exact') && off
f1.lxfs=1767163
y1.lxfs=176716

奇怪的现象来了
? '1767163'='176716'  &&结果是.T.
? f1.lxfs=y1.lxfs    &&结果是.F.,这是为啥?


只有本站会员才能查看附件,请 登录

只有本站会员才能查看附件,请 登录


[此贴子已经被作者于2021-8-22 11:35编辑过]

19 回复
#2
sdta2021-08-22 11:38
静下心来多看看帮助文件是怎么说的
#3
hjlali2021-08-22 12:16
以下是引用sdta在2021-8-22 11:38:52的发言:

静下心来多看看帮助文件是怎么说的

我这几天都在很认真的学习,实在搞不懂了才来论坛提问,求指点指点。
#4
sdta2021-08-22 12:36
多看多练是关键
#5
吹水佬2021-08-22 12:48
回复 楼主 hjlali
没考虑字符串长度属性了。
字符串比较有两个主要属性:对应的字符比对和字符串长度比对。
字符串比较结果:< 或 = 或 >
#6
hjlali2021-08-22 13:01
以下是引用吹水佬在2021-8-22 12:48:06的发言:

没考虑字符串长度属性了。
字符串比较有两个主要属性:对应的字符比对和字符串长度比对。
字符串比较结果:< 或 = 或 >

我前面说过了,两个表中lxfs字段的长度和属性都是一样的,你们自己可以看看表结构。
为什么结果还是.F.呢?
#7
hjlali2021-08-22 13:03
以下是引用sdta在2021-8-22 12:36:45的发言:

多看多练是关键

大师说的对,我也在多看多练,都连续练习两天了,在电脑面前一坐就是七八个小时,是我愚钝,或者是哪里疏忽了。
你能把原因说明白点吗,谢谢了!!

下面几篇文章都学了
只有本站会员才能查看附件,请 登录


[此贴子已经被作者于2021-8-22 13:10编辑过]

#8
pjtyzyq2021-08-22 13:31
? LEN(y1.lxfs)是多少?
你的比较相当于:
f1.lxfs="1767163"
y1.lxfs="176716 "
所以结果不同
#9
hjlali2021-08-22 13:50
以下是引用pjtyzyq在2021-8-22 13:31:11的发言:

? LEN(y1.lxfs)是多少?
你的比较相当于:
f1.lxfs="1767163"
y1.lxfs="176716 "
所以结果不同

? LEN(y1.lxfs)  结果是50
? LEN(f1.lxfs)   结果也是50
他们的长度是一样的。
按照VFP的规则,当为set exact OFF(默认值 )状态时,只要右端字符串与左端字符串的左子串相等,则就认为是真,否则是假。
如:? ′ABC′=′AB′ &&显示  .T.

也就是说,
? f1.lxfs=y1.lxfs   结果应该为.T.,但为什么实际运行结果是.F.呢?我真没弄明白!!
#10
pjtyzyq2021-08-22 14:00
你验证一下?"1767163"="176716 "和?"1767163"="176716"及?"176716"="1767163"

[此贴子已经被作者于2021-8-22 14:03编辑过]

#11
pjtyzyq2021-08-22 14:13
设为off时,比对时按顺序从左到右,各取一个字符比对,一样就继续. 当某个字符串取完了就不继续了, 哪怕另一个字符串仍有字符也算相等。
你的两个变量长度都是50,当比较到7位时,f1.lxfs的第7位是3,y1.lxfs的第7位是空格,所以结果位F
#12
吹水佬2021-08-22 14:25
以下是引用hjlali在2021-8-22 13:01:31的发言:


我前面说过了,两个表中lxfs字段的长度和属性都是一样的,你们自己可以看看表结构。
为什么结果还是.F.呢?

长度一样,那从左到右各字符也一样吗?


#13
吹水佬2021-08-22 16:22
这样看看字符串的比较,设3种结果标志:0,1,-1(相等,大于,小于)
程序代码:
?strcmp("123","123")
?strcmp("1234","123")
?strcmp("123","1234")
?strcmp("1235","1234")
?strcmp("1234","1235")

FUNCTION strcmp(s1, s2)
    i = 1
    DO WHILE (i<LEN(s1) OR i<LEN(s2)) AND ASC(SUBSTR(s1,i,1))==ASC(SUBSTR(s2,i,1))
        i = i + 1
    ENDDO
    ret = ASC(SUBSTR(s1,i,1)) - ASC(SUBSTR(s2,i,1))
    RETURN IIF(ret==0,0,IIF(ret>0,1,-1))
ENDFOR


[此贴子已经被作者于2021-8-22 16:31编辑过]

#14
吹水佬2021-08-22 17:07
再看看字符串比较中的包含和被包含,设4种结果标志:0,1,2,3(相等,包含,被包含,不可比)
PS:示例只谈谈思路,没严格测试
程序代码:
?strinc("123","123")
?strinc("1234","123")
?strinc("123","1234")
?strinc("1235","1234")

FUNCTION strinc(s1, s2)
    IF AT(s2,s1)==1
        RETURN IIF(LEN(s1)==LEN(s2),0,1)
    ENDIF
    RETURN IIF(AT(s1,s2)==1,2,3)
ENDFUN
#15
mywisdom882021-08-23 08:44
回复 6楼 hjlali
? '1767163'='176716'   && .t.
? '1767163'='176716 '  && 后面有个空格 .f.
问题在这里了,VFP表,有的系统,比如WIN7,字符字段的,当字符不够长度时,会在后面补空格

CREATE CURSOR f1(xm c(10),lxfs c(10))
INSERT INTO f1(xm,lxfs) VALUES ('a1','1767163')
CREATE CURSOR y1(xm c(10),lxfs c(10))
INSERT INTO y1(xm,lxfs) VALUES ('a1','176716')
?f1.lxfs=y1.lxfs  && .F.
?ALLTRIM(f1.lxfs)=ALLTRIM(y1.lxfs) && .T.
?LEN(y1.lxfs)  && 10,不是6
你问的问题,就在这里,自动补空格
#16
mywisdom882021-08-23 08:46
改成这样,就不会自动补空格
CREATE CURSOR f1(xm c(10),lxfs v(10))
INSERT INTO f1(xm,lxfs) VALUES ('a1','1767163')
CREATE CURSOR y1(xm c(10),lxfs v(10))
INSERT INTO y1(xm,lxfs) VALUES ('a1','176716')
?f1.lxfs=y1.lxfs
#17
hjlali2021-08-26 21:08
以下是引用mywisdom88在2021-8-23 08:46:30的发言:

改成这样,就不会自动补空格
CREATE CURSOR f1(xm c(10),lxfs v(10))
INSERT INTO f1(xm,lxfs) VALUES ('a1','1767163')
CREATE CURSOR y1(xm c(10),lxfs v(10))
INSERT INTO y1(xm,lxfs) VALUES ('a1','176716')
?f1.lxfs=y1.lxfs

谢谢!我之前以为自动添加的空格不会加入计算,看来是我理解错了!顺便请问V(10)是定义的什么类型?
#18
sdta2021-08-26 21:43
可变字符类型
#19
hjlali2021-08-26 22:19
以下是引用sdta在2021-8-26 21:43:18的发言:

可变字符类型

见多识广,都是高手啊!
#20
laowan0012021-08-27 19:46
? '1767163'='176716'  &&结果是.T.
? alltrim(f1.lxfs)=alltrim(y1.lxfs)    &&看看结果是啥?
1