Excel自定义函数取拼音首字母

1.启动Excel 2003(其它版本请仿照操作),打开相应的工作表;

2.执行"工具 > 宏 > Visual Basic编辑器"命令(或者直接按"Alt+F11"组合键),进入Visual Basic编辑状态;

3.执行"插入 > 模块"命令,插入一个新模块。再双击插入的模块,进入模块代码编辑状态

4.将代码输入其中。代码如下:

复制代码
Function pinyin(p As String) As String
 
i = Asc(p)
 
Select Case i
 
Case -20319 To -20284: pinyin = "a"
 
Case -20283 To -19776: pinyin = "b"
 
Case -19775 To -19219: pinyin = "c"
 
Case -19218 To -18711: pinyin = "d"
 
Case -18710 To -18527: pinyin = "e"
 
Case -18526 To -18240: pinyin = "f"
 
Case -18239 To -17923: pinyin = "g"
 
Case -17922 To -17418: pinyin = "h"
 
Case -17417 To -16475: pinyin = "j"
 
Case -16474 To -16213: pinyin = "k"
 
Case -16212 To -15641: pinyin = "l"
 
Case -15640 To -15166: pinyin = "m"
 
Case -15165 To -14923: pinyin = "n"
 
Case -14922 To -14915: pinyin = "o"
 
Case -14914 To -14631: pinyin = "p"
 
Case -14630 To -14150: pinyin = "q"
 
Case -14149 To -14091: pinyin = "r"
 
Case -14090 To -13319: pinyin = "s"
 
Case -13318 To -12839: pinyin = "t"
 
Case -12838 To -12557: pinyin = "w"
 
Case -12556 To -11848: pinyin = "x"
 
Case -11847 To -11056: pinyin = "y"
 
Case -11055 To -2050: pinyin = "z"
 
Case Else: pinyin = p
 
End Select
 
End Function

Function getpy(str)
 
For i = 1 To Len(str)
 
getpy = getpy & pinyin(Mid(str, i, 1))
 
Next i
 
End Function

5.代码输入完成后,关闭Visual Basic编辑窗口,返回Excel编辑状态;

6.自定义函数就可以用了,如:选中A2单元格,输入公式:=getpy(A2)

相关推荐
chenchihwen2 小时前
大模型应用班-第3课 从Excel到大屏:AI编程实战全解析 HW3 从零到一:香港疫情数据看板开发实战指南
excel·ai编程
33255_40857_280598 小时前
使用EasyPOI实现Java订单数据导出(含多物料信息)——模板语法详解与实战
java·excel
我今晚不熬夜9 小时前
Excel文件解析
excel
开开心心就好10 小时前
PDF转图片工具,一键转换高清无损
服务器·前端·智能手机·r语言·pdf·excel·batch
CodeCraft Studio1 天前
国产化Excel处理组件Spire.XLS教程:使用 Java 将 CSV 转换为 Excel
java·python·excel
宝山哥哥1 天前
python办自动化--利用vba或者python按需求读取excel文件指定列,更改列名后,按照要求将列排序,最后填充空白单元格
python·数据分析·自动化·excel·pandas
修心光1 天前
Excel常用函数大全,非常实用
excel
开开心心就好1 天前
Excel批量加密工具,一键保护多个文件
java·javascript·人工智能·安全·excel·音视频·语音识别
空中湖1 天前
【效率工具】255款工作计划表格Excel电子版模板:总结日月周报日历安排提醒时间管理
程序人生·excel·效率工具
angushine2 天前
Python将Word转换为Excel
python·word·excel