20190227xlVBA辅助输入
Dim tg As Range
Dim FreeInput As Boolean
Private Sub ListBox1_DblClick(ByVal Cancel As MSForms.ReturnBoolean)
Debug.Print "Not tg Is Nothing "; (Not tg Is Nothing)
If Not tg Is Nothing Then
tg.Value = Me.ListBox1.Value
tg.Offset(, 1).Select
End If
End Sub Private Sub ListBox1_KeyDown(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer)
If KeyCode = 9 Or KeyCode = 13 Then
Debug.Print "Not tg Is Nothing "; (Not tg Is Nothing)
If Not tg Is Nothing Then
tg.Value = Me.ListBox1.Value
tg.Offset(, 1).Select
End If
Else End If
End Sub Private Sub Worksheet_SelectionChange(ByVal Target As Range)
Set tg = Target
If Target.Cells.Count = 1 And (Target.Column = 3 Or Target.Column = 4 Or Target.Column = 5) And Target.Row > 3 Then
If Not FreeInput Then
Call ShowTwo
Call TextboxFollow(Target)
Call ListboxFollow(Target)
Call ChangeListboxItems(Me.TextBox1.Text, Target.Column - 2)
Else
Call ShowOne
Me.ListBox1.Clear
Call TextboxFollow(Target)
End If
Else
Call ShowNone
End If
End Sub
Sub ShowTwo()
Me.TextBox1.Visible = True
Me.ListBox1.Visible = True
End Sub
Sub ShowOne()
Me.TextBox1.Visible = True
Me.ListBox1.Visible = False
End Sub
Sub ShowNone()
Me.TextBox1.Visible = False
Me.ListBox1.Visible = False
Me.ListBox1.Clear
End Sub
Sub TextboxFollow(ByVal Rng As Range)
With Me.TextBox1
.Text = Rng.Value
.Visible = True
.Left = Rng.Left
.Top = Rng.Top
.Width = Rng.Width
.Height = Rng.Height
.Activate
End With
End Sub
Sub ListboxFollow(ByVal Rng As Range)
With Me.ListBox1
.Clear
.Visible = True
.Left = Rng.Offset(0, 1).Left
.Top = Rng.Offset(0, 1).Top
.Width = 2 * Rng.Width
.Height = 10 * Rng.Offset(0, 1).Height
End With
End Sub
Private Sub TextBox1_KeyUp(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer)
'Debug.Print KeyCode
If KeyCode = 69 Then
If Shift = 2 Then
FreeInput = Not FreeInput
If FreeInput Then
MsgBox "切换为任意输入状态"
Call Worksheet_SelectionChange(tg)
Else
MsgBox "切换为提示输入状态"
Call Worksheet_SelectionChange(tg)
End If
End If
ElseIf KeyCode = 9 Or KeyCode = 13 Then
If Not FreeInput Then
If Me.ListBox1.ListCount > 0 Then
Me.ListBox1.Activate
Me.ListBox1.ListIndex = 0
End If
Else
If Not tg Is Nothing Then
tg.Value = Me.TextBox1.Text
tg.Offset(, 1).Select
End If
End If
End If
End Sub
Private Sub TextBox1_Change()
Debug.Print "TextBox1_Change"
Call ChangeListboxItems(Me.TextBox1.Text, tg.Column - 2)
End Sub
Sub ChangeListboxItems(ByVal TextInput As String, ByVal DATA_COLUMN As Long)
'If Len(TextInput) > 0 Then
Debug.Print "ChangeListboxItems now"
With ThisWorkbook.Worksheets("data")
endrow = .Cells(.Cells.Rows.Count, DATA_COLUMN).End(xlUp).Row
Me.ListBox1.Clear
For i = 2 To endrow
If InStr(.Cells(i, DATA_COLUMN).Value, TextInput) > 0 Then
Me.ListBox1.AddItem .Cells(i, DATA_COLUMN).Value
End If
Next i
End With
'End If
End Sub
20190227xlVBA辅助输入的更多相关文章
- Eclipse输入任意字母或指定字符出现提示框
Eclipse默认是输入"."的时候会有提示框提示对应的API. 如果想更方便的输入任意字母或者指定的符号出现提示框设置如下: 打开Eclipse,选中“Window”->& ...
- C# 自定义控件,日期时间选择输入插件
权声明:本文为博主原创文章,未经博主允许不得转载. // 为textBox1添加一个日期时间选择控件 DateTimeChoser.AddTo(textBox1); DateTimeChoser.De ...
- HTML5权威指南--标签新变化,文件API,拖放API(简要学习笔记一)
1.标签元素更加语义化 2.内容类型仍然为“text/html” 扩展符仍然为html或者htm. <1>DOCTYPE 声明<!DOCTYPE html>就可 ...
- Sublime Text 3 杂记
Sublime Text 是一个功能强大的代码编辑器(收费,但可无限期试用).由程序员Jon Skinner于2008年1月份所开发出来,它最初被设计为一个具有丰富扩展功能的Vim.Sublime T ...
- 键盘事件keydown、keypress、keyup随笔整理总结(摘抄)
原文1:http://www.cnblogs.com/silence516/archive/2013/01/25/2876611.html 原文2:http://www.cnblogs.com/leo ...
- 基于Jquery Validate 的表单验证
基于Jquery Validate 的表单验证 jquery.validate.js是jquery下的一个验证插件,运用此插件我们可以很便捷的对表单元素进行格式验证. 在讲述基于Jquery Vali ...
- 你有没有试过“闭上眼”使用:京东、滴滴、QQ、支付宝?
正在看这篇文章的同学,也许是幸运的. 互联网的发展,让我们的生活越来越便利,但这个“我们”,也许并不包括那些残障人士.正常人眼里来说再简单不过的页面操作,对于盲人来说都是不可攀越的高墙.换句话说,越行 ...
- Struts个人总结
编写Struts2第一个程序 Struts2是目前最流行的MVC框架,吸收了传统Struts和WebWork两者的精华,基于Struts2来进行开发可以大大减少开发时间,提高开发效率,并降低后期维护时 ...
- Mditor 发布「桌面版」了 - http://mditor.com
简单说明 Mditor 最早只有「组件版」,随着「桌面版」的发布,Mditor 目前有两个版本: 可嵌入到任意 Web 应用的 Embed 版本,这是一桌面版的基础,Repo: https://git ...
随机推荐
- Web开发——HTML基础(文件和网站结构)
参考: 参考:Document and website structure 参考:使用HTML部分和大纲 目录: 1.基本部分 2.用于构造内容的HTML 编辑 2.1 主动学习:探索我们的例子的代码 ...
- [学习] 从 函数式编程 到 lambda演算 到 函数的本质 到 组合子逻辑
函数式编程 阮一峰 <函数式编程初探>,阮一峰是<黑客与画家>的译者. wiki <函数编程语言> 一本好书,<计算机程序的构造与解释>有讲到schem ...
- Linux之grep的使用
基本介绍 Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来.grep全称是Global Regular Expression Print,表示全 ...
- 快速搭建完整zabbix3.4
一.准备工作OS:centos7.4Zabbix version:3.4.6(2018/1/15日上线的新版本)Database:MariaDB关闭防火墙:systemctl stop firewal ...
- SQL SERVER查询的临时文件路径
C:\Users\用户\Documents\SQL Server Management Studio\Backup Files C:\Users\用户\AppData\Local\Temp\
- python练习题-day8
1.有如下文件,a1.txt,里面的内容为: 老男孩是最好的培训机构, 全心全意为学生服务, 只为学生未来,不为牟利. 我说的都是真的.哈哈 分别完成以下的功能: a,将原文件全部读出来并打印. wi ...
- #学号 20175201张驰 《Java程序设计》第1周学习总结
教材学习内容总结 第一章 ·第一章的内容相对简单,我并未遇到大的困难. ·1.Java特点:语法简单.面向对象.与平台无关.动态. ·2.关于编写源文件:源文件名字必须与public类的名字相同:保存 ...
- element-ui table表格展开行每次只能展开一行
https://www.jianshu.com/p/a59c22202f2c <template> <el-table @expand-change="expandSele ...
- eclipse出现An internal error occurred during: "Building workspace". Java heap space 错误
出现这个错误,eclipse 会卡死,以及自动退出 解决方案 工程根目录 找到项目中.project文件 删除这两处 第一处: <buildCommand> <name>org ...
- java之webservice客户端
1.新建客户端项目. 2.配置服务端的wsdl文件位置 3.添加junit的jar包. 4.编写客户端类.