当前位置: 首页 > 图文教程 > 工具软件 > 办公软件 > Excel帮你填写报名信息卡

办公软件
word中插入随excel文件更新的excel表格
减小Word文档的文件大小的6种实用方法
让Word文档自动播放背景音乐
Office 2010让你工作和学习更加方便
PowerPoint宏功能快速批量插入图片
在Powerpoint幻灯片里显示总页数
Office2010最大的创新与手机以及网络连接有关
Word文档中绘图小技巧3则
Word 2007图片应用多种图片样式操作方法
安装Office 2010中文B版提示老版本未删除
最新的Word 2010进行屏幕取词翻译功能
Word文档打开出错,怎么修复?
Word2007粘贴操作心领神会的设置技巧
WPS Office 2009表格编辑区域用户权限设置
Word 2010文档窗口中查看被修改次数
Word文档变为乱码的处理方法
关于Excel宏的小窍门
Excel表格:自动变化的动态表头
Word2007文档快速存为.DOC文档操作设置
岁末盘点国产四大Office办公软件

办公软件 中的 Excel帮你填写报名信息卡


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-01   浏览: 40 ::
收藏到网摘: n/a

    每一年的中、高考报名工作中,查找考生姓名、联系地址的区位码是一项必不可少的工作。查找这些汉字的区位码,通常都要对照一本小册子——《汉字区位码手册》进行查找,这不仅不方便,而且也容易出错。利用office/9.shtml' target='_blank' class='article'>Excel的宏解决了这一问题。

  1. 建立一Excel工作簿,选择sheel1工作表,将所有的考生姓名录入A列中。

  2. 打开“工具/宏”,输入所要创建的宏名(qw),点击〔创建〕。

  3. 在弹出的模块(代码)框中录入如下代码:

  Sub qw()

  Dim i, j, k, l, rs As Integer

  Dim cc As Long

  Dim str, newstr, hz1, hz2, ss As String

  i = 0

  k = 1

  j = 0

  '输入待查姓名人数

  rs = InputBox("待查询姓名区位码人数?", "请输入")

  str = ""

  hz2 = ""

  ss = ""

  For j = 1 To rs

  l = 0

  str = Cells(j, 1).Value

  '读取A列中第J行单元格内的姓名

  For i = 1 To Len(str)

  newstr = newstr + Mid(str, i, 1)

  If Right(Mid(str, i, 1), 1) = " " Then l = l + 1

  Next i

  '过滤掉姓名中的空格

  If ((l > 0) And (Right(newstr, 1) <> " ")) Then hz1 = MidB(newstr, 1, 2) + Right(newstr, 2)

  If ((l > 0) And (Right(newstr, 1) = " ")) Then hz1 = newstr

  If l = 0 Then hz1 = newstr

  If Len(hz1) < 1 Then End

  '计算汉字所对应的区位码

  For k = 1 To Len(hz1) + 2 Step 2

  ss = MidB(hz1, k, 2)

  cc = Asc(ss)

  If cc < 0 Then

  cc = cc + 65535 + 1

  If cc > 255 Then

  b2 = Right("0" && ((cc And 255) - 160), 2)

  b1 = Right("0" && (Int(cc / 256) - 160), 2)

  End If

  End If

  '用"'"分开每一汉字的区位码

  If cc > 255 Then hz2 = hz2 + b1 + b2 + "'"

  Next k

  '在B列中输出A列中相应姓名的区位码

  Cells(j, 2) = hz2

  newstr = ""

  hz2 = ""

  Next j

  End Sub

  4. 在确认A列中已输入完所要查询的考生姓名后,就可以打开“工具/宏”,选择刚刚创建的宏名(qw)。点击〔执行〕,在弹出的对话框中输入想要查询的人数,点击〔确定〕按钮,所有的姓名都被自动转换了。