田草博客

互联网田草博客


网友交流QQ群:11740834 需注明申请加入原因

微信 公众号:ByCAD

邮箱:tiancao1001x126.com
ByCAD,微信公众号
首页 | 普通 | 电脑 | AutoCAD | VB/VB.NET | FLash | 结构 | 建筑 | 电影 | BIM | 规范 | 软件 | ID
-随机-|-分布-
-博客论坛-|-﨣﨤﨧﨨-
-网站导航-|-规范下载-
-BelovedFLash欣赏-

用户登陆
用户:
密码:
 

站点日历
73 2024 - 12 48
1234567
891011121314
15161718192021
22232425262728
293031


站点统计

最新评论



C#使用ITextSharp操作pdf ZXing.Net
未知 VB之中英文混合字符串对齐的方法   [ 日期:2017-12-15 ]   [ 来自:本站原创 ]  HTML
C#语言之“中英文混合字符串对齐”的方法【转】
https://www.cnblogs.com/Pickuper/articles/2059139.html

Public Class Form1

    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
        Dim S1 As String = "图纸名称1"
        Dim NewS1 As String = PadRightEx(S1, 20, "  ")'用占位符号比较好
        Dim S2 As String = "名称A"
        Dim NewS2 As String = PadRightEx(S2, 20, "  ")
        Dim s3 As String = NewS1 & S1 & vbCrLf & NewS2 & S2 & vbCrLf
        MsgBox(s3)
    End Sub
    Private Function PadLeftEx(ByVal str As String, ByVal totalByteCount As Integer, ByVal c As Char) As String
        Dim coding As System.Text.Encoding = System.Text.Encoding.GetEncoding("gb2312")
        Dim dcount As Integer = 0
        For Each ch As Char In str.ToCharArray()
            If coding.GetByteCount(ch.ToString()) = 2 Then
                System.Math.Max(System.Threading.Interlocked.Increment(dcount), dcount - 1)
            End If
        Next
        Dim w As String = str.PadRight(totalByteCount - dcount, c)
        MsgBox(w.Length)
        Return w
    End Function
    Private Function PadRightEx(ByVal str As String, ByVal totalByteCount As Integer, ByVal c As Char) As String
        Dim coding As System.Text.Encoding = System.Text.Encoding.GetEncoding("gb2312")
        Dim dcount As Integer = 0
        For Each ch As Char In str.ToCharArray()
            If coding.GetByteCount(ch.ToString()) = 2 Then
                dcount = dcount + 2
            Else
                dcount = dcount + 1
                'System.Math.Max(System.Threading.Interlocked.Increment(dcount), dcount - 1)
            End If
        Next
        MsgBox(dcount)
        Dim w As String = str.PadRight(totalByteCount - dcount, c)
        MsgBox(w.Length)
        Return w
    End Function
End Class



暂时没有评论
发表评论 - 不要忘了输入验证码哦!
作者: 用户:  密码:   注册? 验证:  防止恶意留言请输入问题答案:1*6=?  
评论:

禁止表情
禁止UBB
禁止图片
识别链接
识别关键字

字体样式 文字大小 文字颜色
插入粗体文本 插入斜体文本 插入下划线
左对齐 居中对齐 右对齐
插入超级链接 插入邮件地址 插入图像
插入 Flash 插入代码 插入引用
插入列表 插入音频文件 插入视频文件
插入缩进符合
点击下载按钮 下标 上标
水平线 简介分割标记
表  情
 
Tiancao Blog All Rights Reserved 田草博客 版权所有
Copyright ©