| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3092 人关注过本帖
标题:VB如何用百分号格式化字符(像%s %d的)
只看楼主 加入收藏
风吹过b
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:364
帖 子:4947
专家分:30084
注 册:2008-10-15
收藏
得分:1 
这样吧,去把 C 的 printf 函数抄过来就是了。
据说,这个函数调了非常多的函数。。。。。。。。。。反正我没看懂。

然后 printf 里还有 VB6 不支持的数据 类型, 那就不支持吧!
int64,有些写成 long long

授人于鱼,不如授人于渔
早已停用QQ了
2022-08-29 13:11
apull
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:三体星系
等 级:版主
威 望:216
帖 子:1506
专家分:9241
注 册:2010-3-16
收藏
得分:0 
回复 10楼 时光流逝
学习了,用这个要省很多事。
2022-08-29 13:44
cwa9958
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:76
帖 子:279
专家分:1367
注 册:2006-6-25
收藏
得分:0 
你的C语言这样是什么意思?你不会用文字解析清楚吗?
反正我看不懂


[此贴子已经被作者于2022-8-29 15:59编辑过]

2022-08-29 15:54
吹水佬
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:451
帖 子:10607
专家分:43186
注 册:2014-5-20
收藏
得分:1 
调用C库API
2022-08-29 15:58
cwa9958
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:76
帖 子:279
专家分:1367
注 册:2006-6-25
收藏
得分:0 
vb对于数据的类型会自动转换,不需要像C那样一定要定义。
2022-08-29 16:03
yuma
Rank: 12Rank: 12Rank: 12
来 自:银河系
等 级:贵宾
威 望:37
帖 子:1934
专家分:3012
注 册:2009-12-22
收藏
得分:0 
搞的不伦不类的

心生万象,万象皆程序!
本人计算机知识网:http://bbs.为防伸手党,本站已停止会员注册。
2022-08-29 16:36
风吹过b
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:364
帖 子:4947
专家分:30084
注 册:2008-10-15
收藏
得分:5 
自己写了一个,有部分太复杂了,放弃支持
调用,按9楼的调用,只是我的函数名为 FormatF ,模拟 printf 函数格式化
注意,有一个地方与 c 不同,也提供与C完全一样的方法(条件编译)

程序代码:
Option Explicit

#Const 斜杠N转意回车换行号 = True

Public Function FormatF(Ss As String, ParamArray F() As Variant) As String
Dim str1 As String              '中间数据的最终结果
Dim i As Long, s As String      'i 循环变量,s 中间判断字符
Dim FL As Long, FU As Long      '可变参数的下标最小值,最大值
Dim FJ As Long                  '可变参数使用的下标
Dim SFU As Long                 '处理%的最大下标
Dim SF() As String              '处理%的分解后的数据

FL = LBound(F)
FU = UBound(F)
If FU < FL Then         '如果除格式字符串外未提供数据
    FormatF = Ss        '原样返回
    Exit Function       '结束函数
End If
FJ = FL

'先处理\
'不能使用替换处理原因:如 \\n 替换会转意错误,不管先替换哪个
'先处理\,可以避免处理参数里后多出 \ 来导致转意错误
    i = 0           '起始搜索位置为1
    str1 = Ss       '原字符不破坏
Do
    i = InStr(i + 1, str1, "\")       '查找
    If i > 0 Then                   '找到,则转意并拼接
        str1 = Left(str1, i - 1) & fxz(Mid(str1, i + 1, 1)) & Mid(str1, i + 2)
    Else
        Exit Do
    End If
Loop

'处理%
'为什么样分割字符串
'如转入参数 "%s","a%d"  ,使用查找法,会导致%s 扩展成 a%d ,然后从下一位开始,导致查找到%d

SF = Split(str1, "%")    '直接按%分割字符串
SFU = UBound(SF)
FJ = FL                  '第一个参数

'注,所有的处理,这里都没对参数是否符合要求进行判断。必须判断。
For i = FL + 1 To SFU    '每一段,第一段为第一个%前的内容,不需要分析
    s = Left(SF(i), 1)   '第一个字符
                         '这里决定不支持修饰,[flags][width][.precision][length]
                         '如果需要支持,则需要从第一个字符查找指定的字符,找到后再分解处理
    '已支持 s d f x X e E c
    Select Case s
        Case "s"            '字符串输出
            If FJ <= FU Then
                SF(i) = F(FJ) & Mid(SF(i), 2)
            End If
            FJ = FJ + 1
        Case "d"            '整数输出,加INT函数,小数只输出整数部分
            If FJ <= FU Then
                SF(i) = str(Int(F(FJ))) & Mid(SF(i), 2)  'str,正数保留前导空格
            End If
            FJ = FJ + 1
        Case "f"             '浮点输出
            If FJ <= FU Then
                SF(i) = Format(F(FJ), "0.##################") & Mid(SF(i), 2)   '小数点后最多18位数
                'SF(i) = Format(F(FJ), "0.000000") & Mid(SF(i), 2)   '小数点后6位数,不足补零,此行未测试
            End If
            FJ = FJ + 1
        Case "x"            '整数按十六进制输出,不会前面补零,字母按小写
            If FJ <= FU Then
                SF(i) = LCase(Hex(F(FJ))) & Mid(SF(i), 2)
            End If
            FJ = FJ + 1
        Case "X"           '整数按十六进制输出,不会前面补零,字母按大写
            If FJ <= FU Then
                SF(i) = Hex(F(FJ)) & Mid(SF(i), 2)
            End If
            FJ = FJ + 1
        Case "e"
            If FJ <= FU Then    '科学计数,保留6位小数,2位指数,未完全测试
                SF(i) = Format(F(FJ), "0.######e-##") & Mid(SF(i), 2)
            End If
            FJ = FJ + 1
        Case "E"
            If FJ <= FU Then    '科学计数,保留6位小数,2位指数,未完全测试
                SF(i) = Format(F(FJ), "0.######E-##") & Mid(SF(i), 2)
            End If
            FJ = FJ + 1
        Case "c"
            If FJ <= FU Then    '调用chr函数后输出,这里超范围也许会导致错误,
                SF(i) = Chr(val(F(FJ))) & Mid(SF(i), 2)
            End If
            FJ = FJ + 1
        Case Else       '不属于以上情况,补上被吃的%
            SF(i) = "%" & SF(i)
            
    End Select
Next i
    str1 = Join(SF, "")
    If FJ > FU + 1 Then     '参数不足
        Err.Raise 450       '创建错误,该错误能被错误处理语句捕捉到,错误的参数个数。DEBUG好用。
    End If

FormatF = str1
End Function


Private Function fxz(ss As String) As String
    Select Case ss       '转意,直接照C抄的

    Case "'", """", "?", "\"        '这四个是原意输出
        fxz = ss
    Case "a"
        fxz = Chr(7)
    Case "b"
        fxz = Chr(8)
    Case "f"
        fxz = Chr(12)
    Case "n"
        #If 斜杠N转意回车换行号 Then    '根据编译选项选择
            fxz = vbCrLf        'windows平台需要2个字符来换行,所以默认用这个
        #Else
            fxz = Chr(10)
        #End If
    Case "r"
        fxz = Chr(13)
    Case "t"
        fxz = Chr(9)
    Case "v"
        fxz = Chr(11)
    Case Else    '非转意(吃掉斜杠)和转成本身字符的
        fxz = ss
        'fxz = "\" & ss        '这种不吃掉斜杠
    End Select
End Function



[此贴子已经被作者于2022-8-29 23:36编辑过]


授人于鱼,不如授人于渔
早已停用QQ了
2022-08-29 23:17
chenyucheng
Rank: 3Rank: 3
来 自:浙江省台州市临海市
等 级:论坛游侠
威 望:3
帖 子:141
专家分:181
注 册:2022-7-1
收藏
得分:0 
有没有通过Windows API来格式化的

爱玩编程的小学生,有Python,但只会一点点C++。

版主->斑竹->竹子,所以版主是竹子。(doge)
//不要让我当版主
2022-08-29 23:38
chenyucheng
Rank: 3Rank: 3
来 自:浙江省台州市临海市
等 级:论坛游侠
威 望:3
帖 子:141
专家分:181
注 册:2022-7-1
收藏
得分:0 
回复 18楼 chenyucheng
论坛私信:
我 : 可以回帖吗?
https://bbs.bccn.net/viewthread.php?tid=509892&page=2#pid2765630
@apull : 木有API的方式,printf是c的功能,不是windows的。
我 : 可能C有,API也有

爱玩编程的小学生,有Python,但只会一点点C++。

版主->斑竹->竹子,所以版主是竹子。(doge)
//不要让我当版主
2022-08-31 22:04
chenyucheng
Rank: 3Rank: 3
来 自:浙江省台州市临海市
等 级:论坛游侠
威 望:3
帖 子:141
专家分:181
注 册:2022-7-1
收藏
得分:0 
回复 19楼 chenyucheng
续:
@apull : 可以自己写用c写个dll,返回字符串,vb输出。

爱玩编程的小学生,有Python,但只会一点点C++。

版主->斑竹->竹子,所以版主是竹子。(doge)
//不要让我当版主
2022-08-31 22:21
快速回复:VB如何用百分号格式化字符(像%s %d的)
数据加载中...
 
   



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

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