热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

PHP汉字、拼音、unicode、声母、韵母互相转换-PHP源码

PHP汉字、拼音、unicode、声母、韵母互相转换
 汉字
			"pinyin"	=> 拼音
			"pinyin_s"	=> 声母
			"pinyin_y"	=> 韵母
			"type"		=> 声调(1,2,3,4)
			"unicode"	=> 汉字unicode
 * 		   );
 */

define('IM_FEIYAN', true);
include_once 'config.php';	

$data['words'] = null;
$data_root = &$data['words'];

$word = strtolower(urldecode(Filter::http_get("word")));
if( empty($word) ){
        $data_root['result_code'] = 0;
	$data_root['desc'] = "Parameter Word Can't be Empty";
} else {
	$page = Filter::http_get("page");
	$page = !empty($page) && intval($page)>=1 ? intval($page) : 1;
	$size = Filter::http_get("size");
	$size = !empty($size) && intval($size)>=1 ? intval($size) : 10;
	$set = ( $page-1 )*$size;
	//fuzzy:模糊查询	accurate:精确查询
	$act  = Filter::http_get("act");
	$act = in_array($act,array("fuzzy","accurate")) ? $act : "fuzzy";
	if( $act == "fuzzy" ) {
		$sql = "SELECT COUNT(id) FROM words WHERE search_index LIKE '%{$word}%'";
		$total = $db->getone($sql);
		$pages = $total%$size==0 ? intval($total/$size) : intval($total/$size)+1;
		$sql = "SELECT * FROM words WHERE search_index LIKE '%{$word}%' LIMIT $set,$size";
		
	} elseif ( $act == "accurate" ) {
		$column = preg_match("/^[a-z]+$/",$word) ? "pinyin"
				: ( preg_match("/^[\x{4e00}-\x{9fa5}]+$/u",$word) ? "word" : "unicode");
		$sql = "SELECT COUNT(id) FROM words WHERE $column LIKE '%{$word}%'";
		$total = $db->getone($sql);
		$pages = $total%$size==0 ? intval($total/$size) : intval($total/$size)+1;
		$sql = "SELECT * FROM words WHERE $column LIKE '%{$word}%' LIMIT $set,$size";
	}
	$res = $db->getall($sql);
	if( empty($res) ){
		$data_root['result_code'] = 1;
		$data_root['desc'] = 'Data is Empty';
	} else {
		foreach ( $res as &$row )
		{
			$data_root["word"][] = array(
				"word"		=> $row["word"],
				"pinyin"	=> $row["pinyin"],
				"pinyin_s"	=> $row["pinyin_s"],
				"pinyin_y"	=> $row["pinyin_y"],
				"type"		=> $row["type"],
				"unicode"	=> "\"".$row["unicode"]."\""
			);
		}
	}
}

//导出XML或者json
output( $data );
?>

推荐阅读
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • YOLOv7基于自己的数据集从零构建模型完整训练、推理计算超详细教程
    本文介绍了关于人工智能、神经网络和深度学习的知识点,并提供了YOLOv7基于自己的数据集从零构建模型完整训练、推理计算的详细教程。文章还提到了郑州最低生活保障的话题。对于从事目标检测任务的人来说,YOLO是一个熟悉的模型。文章还提到了yolov4和yolov6的相关内容,以及选择模型的优化思路。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 在使用dedecms过程中,添加自定义字段变量很有用,但删除并不容易。本文介绍了两种常用的删除方法:执行SQL语句和手动SQL删除。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
author-avatar
黑山一般人
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有