# 字符串辅助函数
字符串辅助函数文件包含了一些帮助你处理字符串的函数。
[TOC=2,3]
## [加载辅助函数](http://codeigniter.org.cn/user_guide/helpers/string_helper.html#id4)
该辅助函数通过下面的代码加载:
~~~
$this->load->helper('string');
~~~
## [可用函数](http://codeigniter.org.cn/user_guide/helpers/string_helper.html#id5)
该辅助函数有下列可用函数:
random_string([$type = 'alnum'[, $len = 8]])
参数:
* **$type** (string) -- Randomization type
* **$len** (int) -- Output string length
返回: A random string
返回类型: string
根据你所指定的类型和长度产生一个随机字符串。可用于生成密码或随机字符串。
第一个参数指定字符串类型,第二个参数指定其长度。有下列几种字符串类型可供选择:
* **alpha**: 只含有大小写字母的字符串
* **alnum**: 含有大小写字母以及数字的字符串
* **basic**: 根据 mt_rand() 函数生成的一个随机数字
* **numeric**: 数字字符串
* **nozero**: 数字字符串(不含零)
* **md5**: 根据 md5() 生成的一个加密的随机数字(长度固定为 32)
* **sha1**: 根据 sha1() 生成的一个加密的随机数字(长度固定为 40)
使用示例:
~~~
echo random_string('alnum', 16);
~~~
注解
unique 和 encrypt 类型已经废弃,它们只是 md5 和 sha1 的别名。
increment_string($str[, $separator = '_'[, $first = 1]])
参数:
* **$str** (string) -- Input string
* **$separator** (string) -- Separator to append a duplicate number with
* **$first** (int) -- Starting number
返回: An incremented string
返回类型: string
自增字符串是指向字符串尾部添加一个数字,或者对这个数字进行自增。 这在生成文件的拷贝时非常有用,或者向数据库中某列(例如 title 或 slug)添加重复的内容, 但是这一列设置了唯一索引时。
使用示例:
~~~
echo increment_string('file', '_'); // "file_1"
echo increment_string('file', '-', 2); // "file-2"
echo increment_string('file_4'); // "file_5"
~~~
alternator($args)
参数:
* **$args** (mixed) -- A variable number of arguments
返回: Alternated string(s)
返回类型: mixed
当执行一个循环时,让两个或两个以上的条目轮流使用。示例:
~~~
for ($i = 0; $i < 10; $i++)
{
echo alternator('string one', 'string two');
}
~~~
你可以添加任意多个参数,每一次循环后下一个条目将成为返回值。
~~~
for ($i = 0; $i < 10; $i++)
{
echo alternator('one', 'two', 'three', 'four', 'five');
}
~~~
注解
如果要多次调用该函数,可以简单的通过不带参数重新初始化下。
repeater($data[, $num = 1])
参数:
* **$data** (string) -- Input
* **$num** (int) -- Number of times to repeat
返回: Repeated string
返回类型: string
重复生成你的数据。例如:
~~~
$string = "\n";
echo repeater($string, 30);
~~~
上面的代码会生成 30 个空行。
注解
该函数已经废弃,使用原生的 str_repeat() 函数替代。
reduce_double_slashes($str)
参数:
* **$str** (string) -- Input string
返回: A string with normalized slashes
返回类型: string
将字符串中的双斜线('//')转换为单斜线('/'),但不转换 URL 协议中的双斜线(例如:[http://](http://codeigniter.org.cn/user_guide/helpers/string_helper.html))
示例:
~~~
$string = "http://example.com//index.php";
echo reduce_double_slashes($string); // results in "http://example.com/index.php"
~~~
strip_slashes($data)
参数:
* **$data** (mixed) -- Input string or an array of strings
返回: String(s) with stripped slashes
返回类型: mixed
移除一个字符串数组中的所有斜线。
示例:
~~~
$str = array(
'question' => 'Is your name O\'reilly?',
'answer' => 'No, my name is O\'connor.'
);
$str = strip_slashes($str);
~~~
上面的代码将返回下面的数组:
~~~
array(
'question' => "Is your name O'reilly?",
'answer' => "No, my name is O'connor."
);
~~~
注解
由于历史原因,该函数也接受一个字符串参数,这时该函数就相当于 stripslashes() 的别名。
trim_slashes($str)
参数:
* **$str** (string) -- Input string
返回: Slash-trimmed string
返回类型: string
移除字符串开头和结尾的所有斜线。例如:
~~~
$string = "/this/that/theother/";
echo trim_slashes($string); // results in this/that/theother
~~~
注解
该函数已废弃,使用原生的 trim() 函数代替: | | trim($str, '/');
reduce_multiples($str[, $character = ''[, $trim = FALSE]])
参数:
* **$str** (string) -- Text to search in
* **$character** (string) -- Character to reduce
* **$trim** (bool) -- Whether to also trim the specified character
返回: Reduced string
返回类型: string
移除字符串中重复出现的某个指定字符。例如:
~~~
$string = "Fred, Bill,, Joe, Jimmy";
$string = reduce_multiples($string,","); //results in "Fred, Bill, Joe, Jimmy"
~~~
如果设置第三个参数为 TRUE ,该函数将移除出现在字符串首尾的指定字符。例如:
~~~
$string = ",Fred, Bill,, Joe, Jimmy,";
$string = reduce_multiples($string, ", ", TRUE); //results in "Fred, Bill, Joe, Jimmy"
~~~
quotes_to_entities($str)
参数:
* **$str** (string) -- Input string
返回: String with quotes converted to HTML entities
返回类型: string
将字符串中的单引号和双引号转换为相应的 HTML 实体。例如:
~~~
$string = "Joe's \"dinner\"";
$string = quotes_to_entities($string); //results in "Joe's "dinner""
~~~
strip_quotes($str)
参数:
* **$str** (string) -- Input string
返回: String with quotes stripped
返回类型: string
移除字符串中出现的单引号和双引号。例如:
~~~
$string = "Joe's \"dinner\"";
$string = strip_quotes($string); //results in "Joes dinner"
~~~
- 欢迎使用 CodeIgniter
- 安装说明
- 下载 CodeIgniter
- 安装说明
- 从老版本升级
- 疑难解答
- CodeIgniter 概览
- CodeIgniter 将从这里开始
- CodeIgniter 是什么?
- 支持特性
- 应用程序流程图
- 模型-视图-控制器
- 设计与架构目标
- 教程 - 内容提要
- 加载静态内容
- 读取新闻条目
- 创建新闻条目
- 结束语
- 常规主题
- CodeIgniter URL
- 控制器
- 保留名称
- 视图
- 模型
- 辅助函数
- 使用 CodeIgniter 类库
- 创建类库
- 使用 CodeIgniter 驱动器
- 创建驱动器
- 创建核心系统类
- 创建附属类
- 钩子 - 扩展框架核心
- 自动加载资源
- 公共函数
- 兼容性函数
- URI 路由
- 错误处理
- 网页缓存
- 程序分析
- 以 CLI 方式运行
- 管理你的应用程序
- 处理多环境
- 在视图文件中使用 PHP 替代语法
- 安全
- PHP 开发规范
- 类库参考
- 基准测试类
- 缓存驱动器
- 日历类
- 购物车类
- 配置类
- Email 类
- 加密类
- 加密类(新版)
- 文件上传类
- 表单验证类
- FTP 类
- 图像处理类
- 输入类
- Javascript 类
- 语言类
- 加载器类
- 迁移类
- 输出类
- 分页类
- 模板解析类
- 安全类
- Session 类
- HTML 表格类
- 引用通告类
- 排版类
- 单元测试类
- URI 类
- 用户代理类
- XML-RPC 与 XML-RPC 服务器类
- Zip 编码类
- 数据库参考
- 数据库快速入门: 示例代码
- 数据库配置
- 连接你的数据库
- 查询
- 生成查询结果
- 查询辅助函数
- 查询构造器类
- 事务
- 数据库元数据
- 自定义函数调用
- 数据库缓存类
- 数据库工厂类
- 数据库工具类
- 数据库驱动器参考
- 辅助函数参考
- 数组辅助函数
- 验证码辅助函数
- Cookie 辅助函数
- 日期辅助函数
- 目录辅助函数
- 下载辅助函数
- 邮件辅助函数
- 文件辅助函数
- 表单辅助函数
- HTML 辅助函数
- 语言辅助函数
- Inflector 辅助函数
- 数字辅助函数
- 路径辅助函数
- 安全辅助函数
- 表情辅助函数
- 字符串辅助函数
- 文本辅助函数
- 排版辅助函数
- URL 辅助函数
- XML 辅助函数
- 向 CodeIgniter 贡献你的力量