输入时逐步提示信息.doc

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
输入时逐步提示信息

输入时逐步提示信息 用户在录入数据时,比如在工作表中输入产品名称,除了希望有所有产品名称的下拉列表供选择外,更希望能逐步给出提示信息。比如在输入一两个字符后把符合条件的数据筛选出来供选择,最好是中英文、拼音首字母、大小写能混合查询,如输入“LJ”或“六角”后所有以“六角”开头的产品名称都筛选到列表中供选择,这将大大提高录入速度和正确率。 为了达到这一目的,首先在工作簿需要有如图 1141所示的基础数据表。 图 1141 基础数据表 基础数据表中A列保存不重复的产品名称,为了能用中英文、拼音首字母、大小写混合查询,要把产品名称转换成小写的拼音首字母保存在B列。 步骤1:在VBE窗口单击菜单“插入”→“模块”,在代码窗口写入下面的代码。 #001 Public Function LChin(Str As String) As Variant #002 On Error Resume Next #003 Str = StrConv(Str, vbNarrow) #004 If Asc(Str) 0 Or Err.Number = 1004 Then LChin = #005 LChin = WorksheetFunction.VLookup(Str, [{吖,a;八,b;嚓,c;咑,d;鵽,e;发,f;猤,g;铪,h;夻,j;咔,k;垃,l;嘸,m;旀,n;噢,o;妑,p;七,q;囕,r;仨,s;他,t;屲,w;夕,x;丫,y;帀,z}], 2) #006 End Function 代码解析: 自定义LChin函数,该函数把中文字符转换为拼音首字母。 步骤2:在VBE窗口双击Sheet2表,在代码窗口写入下面的代码。 #001 Private Sub Worksheet_Change(ByVal Target As Range) #002 Dim i As Integer #003 Dim myStr As String #004 With Target #005 If .Column 1 Or .Count 1 Then Exit Sub #006 If WorksheetFunction.CountIf(Sheet2.Range(A:A), .Value) 1 Then #007 .Value = #008 MsgBox 不能输入重复的产品名称!, 64 #009 Exit Sub #010 End If #011 For i = 1 To Len(.Value) #012 If Asc(Mid$(.Value, i, 1)) 255 Or Asc(Mid$(.Value, i, 1)) 0 Then #013 myStr = myStr LChin(Mid$(.Value, i, 1)) #014 Else #015 myStr = myStr LCase(Mid$(.Value, i, 1)) #016 End If #017 Next #018 .Offset(, 1).Value = myStr #019 End With #020 End Sub 代码解析: 工作表的Change事件,当A列输入不重复的产品名称后,转换成小写的字母保存在B列的单元格中,便于以后的查询。 第11行代码,设置事件触发的条件,只有在A列输入产品名称后才触发Change事件。 第12行到第16行代码,使用工作表CountIf函数检查输入的产品名称是否重复。 第17行到第23行代码,字符的转换过程。首先检查是否是中文字符,如果是使用自定义函数LChin转换成小写拼音首字母。如果是大写的英文字母使用LCase函数转换成小写字母。 第24行代码,将转换后的字符保存到B列。 步骤3:基础数据表完成后,在工作表“录入表”中添加一个文本框控件和一个列表框控件。在VBE窗口中双击Sheet1表,写入下面的代码。 #001 Private Sub Worksheet_SelectionChange(ByVal Target As Range) #002 Dim i As Integer #003 If Target.Count = 1 Then #004 If Target.Co

文档评论(0)

mv2323 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档