Foxtable(狐表)用户栏目专家坐堂 → 分隔符和词组转换、组合问题


  共有2186人关注过本帖树形打印复制链接

主题:分隔符和词组转换、组合问题

帅哥哟,离线,有人找我吗?
旭日生
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:小狐 帖子:339 积分:3364 威望:0 精华:0 注册:2011/3/22 22:52:00
分隔符和词组转换、组合问题  发帖心情 Post By:2019/4/26 16:37:00 [只看该作者]

请版主见红字部分。怎么也调试不好,选择组合列如何获利,没有思路。请帮助,谢谢!


图片点击可在新窗口打开查看此主题相关图片如下:image 572.jpg
图片点击可在新窗口打开查看

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:test001.foxdb

[此贴子已经被作者于2019/4/26 16:38:07编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:106558 积分:541955 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/4/26 17:02:00 [只看该作者]

具体什么地方有问题?

 回到顶部
帅哥哟,离线,有人找我吗?
旭日生
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:小狐 帖子:339 积分:3364 威望:0 精华:0 注册:2011/3/22 22:52:00
  发帖心情 Post By:2019/4/26 17:47:00 [只看该作者]

复制一下“清明/英烈”,写入字词列取可看出了。

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:106558 积分:541955 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/4/26 20:45:00 [只看该作者]

'''
Dim str1 As String
Dim str2 As String = " "
Dim str3 As String = " "
Dim str4 As String = " "

Select Case e.DataCol.name
    
    Case "字词"
        If e.DataRow.IsNull("字词") Then
            e.DataRow("数字代码") = Nothing '如果为空,则清除数字代码
            e.DataRow("拼音") = Nothing '如果为空,则清除拼音
        Else
            '            For i As Integer = 0 To e.DataRow("字词").Length -1
            '                str1 = e.DataRow("字词").SubString(i,1) '从字词中选取1个字符
            '               str2 = str2 & str1 & "/"
            '              e.DataRow("数字代码") =str2 '写入数字代码
            '         Next
            
            
            Dim Value As String = e.DataRow("字词")
            Dim sps() As Char = {"/","|",",","。",",","!","!","?","?" }
            Dim Names() As String  = Value.Split(sps)
            For Each name As String In Names
                str3 = str3 & GetPinYin(name) & "/" '分隔符内词转换成拼音
                
            Next
            e.DataRow("拼音") = str3.Trim("/")
        End If
        
    Case  "拼音"
        If  e.DataRow.IsNull("拼音")  Then
            e.DataRow("数字代码")= Nothing
        Else
            Dim Value As String = e.DataRow("拼音")
            Dim Values1() As String
            Dim Values2() As String
            Values1 = value.split("/")
            For Index1 As Integer = 0 To Values1.Length - 1
                '            msgbox(Values1.Length - 1)
                
                '        Values1 = Multi.split("/")
                '        For Index1 As Integer = 0 To values1.Length - 1
                '            msgbox(multi.Length - 1)
                '                msgbox(Values1(Index1))
                
                Values2 = Values1(Index1).trim().split(" ") '赋值拼音分隔符内拼音为Values2
                Dim strv As String = ""
                For Index2 As Integer = 0 To Values2.Length - 1
                    '                    msgbox(values2(Index2))
                    '                    msgbox(Values2.Length - 1)
                    Dim p1 As String = Values2(Index2).SubString(0,1) '定义p1为Values2中第一个拼音第1个字符,如qing ming 中的“q"
                    Dim p2 As String = Values2(Index2).SubString(0,2)'定义p2为Values2中第一个拼音第2个字符,如shui ji 中的“sh"
                    Dim p10 As String = Values2(Index2).SubString(1)'定义p10为Values2中第一段拼音,如2 shui ji中的第一个拼音shui
                    Dim p20 As String = Values2(Index2).SubString(2)'定义p20为Values2中第二段拼音,如2 shui ji中的第二个拼音ji
                    
                    '分辨声母是否为"zh"/"ch"/"sh"
                    If p2 = "zh" OrElse p2 = "ch" OrElse p2 = "sh" Then
                        Dim dr1 As DataRow = DataTables("表A").Find("'/'+ [第二列]+'/' like  '%/" & p2 & "/%' ") '从表A中拼音声母中寻找p2,即zh/ch/sh对应的数字代码
                        Dim dr2 As DataRow = DataTables("表A").Find("'/'+ [第三列]+'/' Like  '%/" & p20 & "/%' ")'从表A中数字代码韵母中寻找P
                        
                        If dr1 Is Nothing   Then
                            strv  = strv & ","
                        Else
                            strv = strv & "," & dr1("第一列") & "-"  & dr2("第一列")
                            
                        End If
                        
                    Else
                        ' msgbox(Values2(Index2).SubString(0,1))
                        ' msgbox(Values2(Index2).SubString(1))
                        
                        Dim dr3 As DataRow = DataTables("表A").find("'/'+ [第二列]+'/' like  '%/" & p1 & "/%' ")
                        Dim dr4 As DataRow = DataTables("表A").find("'/'+ [第三列]+'/' Like  '%/" & p10 & "/%' ")'
                        If dr3 Is Nothing   Then
                            strv  = strv & ","
                        Else
                            strv = strv & "," & dr3("第一列") & "-"  & dr4("第一列")
                            
                        End If
                    End If
                    
                Next
                e.DataRow("数字代码") = e.DataRow("数字代码") & "/" & strv.Trim(",")
            Next
            e.DataRow("数字代码") = e.DataRow("数字代码") .trim("/")
        End If
        
End Select

 回到顶部
帅哥哟,离线,有人找我吗?
旭日生
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:小狐 帖子:339 积分:3364 威望:0 精华:0 注册:2011/3/22 22:52:00
  发帖心情 Post By:2019/4/27 0:10:00 [只看该作者]

好厉害!谢谢蓝版。先学习消化一下。

 回到顶部