站长中国
设为首页 | 站长论坛

站长论坛 站长下载
您所在的位置: 站长中国 > 站长学院 > 网络编程 > ASP专区 > 正文

ASP汉字转拼音,支持自定义特殊词语
站长中国会员投稿  2008年07月29日00:57:46  hayden 评论(0条) 字体:[ ]
相关热点:

这次更新了一下自已所用的博客程序,将生成静态文件时的文件名用文章标题的拼音,这就涉及到如何将文字转成拼音了,在网上大概的看了看,千篇一律的那个函数,应该只可以在GB2312下正常,也没有做太多考虑,这就拿出了曾在无忧系统的源码里看到过的一段用上了。

来看看下面的函数,加入少量注释:

这是一个自定义特殊词语的一个函数

以下为引用的内容:
Function getEnglish(ByVal Str)
    getEnglish = Str
 getEnglish = Replace(getEnglish, "中国", " china ")
 getEnglish = Replace(getEnglish, "策划", " plan ")
 getEnglish = Replace(getEnglish, "免费", " free ")
 getEnglish = Replace(getEnglish, "介绍", " intro ")
 getEnglish = Replace(getEnglish, "技巧", " skill ")
 getEnglish = Replace(getEnglish, "生活", " life ")
 getEnglish = Replace(getEnglish, "活动", " activity ")
 getEnglish = Replace(getEnglish, "工具", " tool ")
 getEnglish = Replace(getEnglish, "联盟", " union ")
 getEnglish = Replace(getEnglish, "注册", " register ")
 getEnglish = Replace(getEnglish, "经验", " experience ")
 getEnglish = Replace(getEnglish, "翻译", " translate ")
 getEnglish = Replace(getEnglish, "项目", " item ")
 getEnglish = Replace(getEnglish, "网站", " web-site ")
 getEnglish = Replace(getEnglish, "英语", " english ")
 getEnglish = Replace(getEnglish, "英文", " english ")
 getEnglish = Replace(getEnglish, "雅虎", " yahoo ")
 getEnglish = Replace(getEnglish, "新浪", " sina ")
 getEnglish = Replace(getEnglish, "支付宝", " alipay ")
 getEnglish = Replace(getEnglish, "交易", " trade ")
 getEnglish = Replace(getEnglish, "网店", " b2c ")
 getEnglish = Replace(getEnglish, "升级", " update ")
 getEnglish = Replace(getEnglish, "杂志", " magazine ")
 getEnglish = Replace(getEnglish, "空间", " space ")
 getEnglish = Replace(getEnglish, "爱情", " love ")
 getEnglish = Replace(getEnglish, "朋友", " friend ")
 getEnglish = Replace(getEnglish, "友情", " friend ")
 getEnglish = Replace(getEnglish, "链接", " like ")
 getEnglish = Replace(getEnglish, "标签", " label ")
 getEnglish = Replace(getEnglish, "运行", " running ")
 getEnglish = Replace(getEnglish, "管理", " manager ")
 getEnglish = Replace(getEnglish, "管理", " manage ")
 getEnglish = Replace(getEnglish, "页面", " page ")
 getEnglish = Replace(getEnglish, "模板", " template ")
 getEnglish = Replace(getEnglish, "游戏", " game ")
 getEnglish = Replace(getEnglish, "论坛", " forum ")
 getEnglish = Replace(getEnglish, "新闻", " news ")
 getEnglish = Replace(getEnglish, "音乐", " music ")
 getEnglish = Replace(getEnglish, "帮助", " help ")
 getEnglish = Replace(getEnglish, "优化", " optimize ")
 getEnglish = Replace(getEnglish, "软件", " soft ")
 getEnglish = Replace(getEnglish, "教程", " tech ")
 getEnglish = Replace(getEnglish, "下载", " download ")
 getEnglish = Replace(getEnglish, "搜索", " search ")
 getEnglish = Replace(getEnglish, "引擎", " engine ")
 getEnglish = Replace(getEnglish, "蜘蛛", " spider ")
 getEnglish = Replace(getEnglish, "日志", " log ")
 getEnglish = Replace(getEnglish, "博客", " blog ")
 getEnglish = Replace(getEnglish, "百度", " baidu ")
 getEnglish = Replace(getEnglish, "谷歌", " google ")
 getEnglish = Replace(getEnglish, "邮箱", " mailbox ")
 getEnglish = Replace(getEnglish, "邮件", " mail ")
 getEnglish = Replace(getEnglish, "域名", " domain ")
 getEnglish = Replace(getEnglish, "测试", " test")
 getEnglish = Replace(getEnglish, "演示", " demo ")
 getEnglish = Replace(getEnglish, "音乐", " music ")
 getEnglish = Replace(getEnglish, "笑话", " joke ")
 getEnglish = Replace(getEnglish, "产品", " product ")
 getEnglish = Replace(getEnglish, "留言", " message ")
 getEnglish = Replace(getEnglish, "反馈", " freedback ")
 getEnglish = Replace(getEnglish, "评论", " comment ")
 getEnglish = Replace(getEnglish, "推荐", " commend ")
 getEnglish = Replace(getEnglish, "共享", " share ")
 getEnglish = Replace(getEnglish, "资源", " resource ")
 getEnglish = Replace(getEnglish, "插件", " plugins ")
 getEnglish = Replace(getEnglish, "本本", " notebook ")
 getEnglish = Replace(getEnglish, "电脑", " computer ")
 getEnglish = Replace(getEnglish, "系统", " system ")
 getEnglish = Replace(getEnglish, "学校", " school ")
 getEnglish = Replace(getEnglish, "无忧", " 5u ")
 getEnglish = Replace(getEnglish, "工作", " job ")
 getEnglish = Replace(getEnglish, "信息", " info ")
 getEnglish = Replace(getEnglish, "娱乐", " ent ")
 getEnglish = Replace(getEnglish, "汽车", " car ")
 getEnglish = Replace(getEnglish, "手机", " mobile ")
 getEnglish = Replace(getEnglish, "网络", " network ")
 getEnglish = Replace(getEnglish, "老板", " boss ")
 getEnglish = Replace(getEnglish, "狗", " dog ")
 getEnglish = Replace(getEnglish, "电视", " tv ")
 getEnglish = Replace(getEnglish, "电影", " movie ")
End Function

然后就是最关键的函数pinyin(byval chinese) 他将中文转换到拼音

以下为引用的内容:
function pinyin(byval chinese)
    chinese = replace(chinese, "/", ""): chinese = replace(chinese, "\", "")
    chinese = replace(chinese, "*", ""): chinese = replace(chinese, "]", "")
    chinese = replace(chinese, "[", ""): chinese = replace(chinese, "}", "")
    chinese = replace(chinese, "{", ""): chinese = replace(chinese, "'", "")
    chinese = getEnglish(chinese) '在这里使用getEnglish先将特殊词语转换
    dim pinyinstr, istr, iIsCn, IsCn
    dim pinyinconn, rs, i, x
    '在这里打开拼音库
    '你也可以将拼音库的并入你的程序数据库里.
    on error resume next
    set pinyinconn = server.createobject("Adodb.connection")
    pinyinconn.open "Provider=Microsoft.Jet.OLEdb.4.0;Data Source=" & server.mappath("pinyin.Asp")
    if err then pinyin = "": set pinyinconn = nothing: exit function
    IsCn = true
    for i = 1 to len(chinese)
    iIsCn = IsCn ' 获取上次是不是中文的值
    istr = Mid(chinese, i, 1)
    x = Asc(istr)
    if (x >= 65 and x <= 90) or (x >= 97 and x <= 122) or (x >= 48 and x <= 57) or istr = " " then
        IsCn = false ' 这些是英文,数字(保留字符),不改动
        if istr = " " then istr = "-"
    else
        set rs = pinyinconn.execute("select Top 1 [pinyin] From [pinyin] Where [content] like '%" & istr & "%';")
        if not rs.eof then
        istr = lcase(rs(0)): IsCn = true   ' 中文
        else
        IsCn = false
        if istr = " " then istr = "-" else istr = "" ' 将空格转换成-,如果是其他字符则清除
        end if
        rs.close: set rs = nothing
    end if
    if iIsCn = IsCn then pinyinstr = pinyinstr & istr else pinyinstr = pinyinstr & "-" & istr
    pinyinstr = replace(pinyinstr, "--", "-")
    pinyinstr = replace(pinyinstr, "__", "_")
    next
    if right(pinyinstr, 1) = "-" then pinyinstr = left(pinyinstr, len(pinyinstr) - 1)
    if right(pinyinstr, 1) = "_" then pinyinstr = left(pinyinstr, len(pinyinstr) - 1)
    if left(pinyinstr, 1) = "-" then pinyinstr = right(pinyinstr, len(pinyinstr) - 1)
    if left(pinyinstr, 1) = "_" then pinyinstr = right(pinyinstr, len(pinyinstr) - 1)
    pinyinconn.close
    set pinyinconn = nothing
    pinyin = trim(pinyinstr)
end Function

使用方法:

以下为引用的内容:
response.write pinyin("中国你好,欢迎来到站长中国!")

这种方法,转换成的拼音格式文件名非常友好,对SEO方面有要求的小程们,可以试试的。



收藏本文 打印 打印本文  推荐本文 告诉好友 投稿 投稿邮箱

站长排行

学院

新闻

专栏

盈利

[揭密网络黄链]中国留学生买凶专破日本
windows 2008中文版iis7+asp+php+Acces
贴吧发帖机使用教程(绝对原创)
超强弹出窗口代码,什么都挡不住
Windows Vista局域网网络连接设置
JSP语法(6)
FLASH视觉特效实例之地震效果
关于数据分页(转自www.codeproject.co
教你如何在Vista中设置麦克风
不用Photoshop 在线恶搞大头像
全国哀悼日网友自发QQ隐身上线 向死难
淘宝网卖家公然叫卖“艳照门”照片集
抗震救灾/鱼目混珠?
Google绿色专家质疑黑色背景网页节省资
阿里妈妈广告卖主全攻略
电影小说类相关关键字搜索量列表
爆笑 阿里就这样把亿告征服!
大脚:实战单页面优化关键词之——淘宝
国内各IT企业办公环境揭秘(多图)
心系灾区,点燃希望——手机QQ2008祈福
ECSHOP模板制作参考文档
悬挂阿里妈妈会否被百度惩罚
ECSHOP模板下载
阿里妈妈是否是中小站长的救世主?
最强网店ECShop发新版 众多酷炫功能给
土豆网,优酷网,爆米花等视频网站采集
DedeCms模板安装/制作概述
网上商店系统巅峰对决 ECShop vs ShopE
编程中国全站采集规则
http://www.mt86.com全站采集规则
性福联盟 一个不尊重站长的联盟
百度网络广告利润增长将会持续多久
大脚:日赚100元—揭露最新firefox欺骗
分享经验:个人网站如何月赚1万!
大脚:垃圾站超级赚钱法之二—突破“站
迅雷联盟、快车联盟收入对比
大脚:垃圾站超级赚钱法之——前言
Google Adsense的秘密 第二版
风险投资公司vc联系方式名录大全(一)
经理人必看的十个管理网站
站长学院  网页设计 建站教程 图形图象 网络编程

制定完整的网站
制定完整的网站
中国企业网站的
中国企业网站的

网站运营之怎么样来粘住你的用
网麒:网站建设创意
怎样提高网页快照更新
两种方法,教你如何通过微软正
英文网站优化细节
利用SSL加密增强FTP服务器的安
网页设计常用Javascript经典代

新闻线索

如果你有站长界人事变动、重组并购、变革技术出现,以及产品投诉等重要新闻线索,请告诉我们,我们会给予特别关注。
0631-3653338
站长中国编辑部
站长中国24小时新闻热线: 13156089008