您的当前位置:首页>全部文章>文章详情

【PHP】PHP去除字符串中的标点符号

CrazyPanda发表于:2024-11-11 15:42:57浏览:237次TAG: #php

1. 使用str_replace()

public function removePunctuation($string)
    {
        $punctuation = array(",", "。", "!", "?", ";");
        return str_replace($punctuation, "", $string);
    }

2. 使用正则表达式

$ string = "Hello, World! 123";
 $ pattern = '/[^A-Za-z0-9s]/';
 $ replacement = '';
 $ cleanedString = preg_replace( $ pattern,  $ replacement,  $ string);
echo  $ cleanedString; // 输出 "Hello World 123"

这里的正则表达式/[^A-Za-z0-9s]/匹配所有非字母、非数字和非空格的字符,然后将其替换为空。

3. 使用ctype_punct函数

$ string = "Hello, World! 12345";
 $ clean_str = str_replace(str_split(implode('', array_intersect_key(str_split( $ string), array_filter(str_split( $ string), 'ctype_punct')))), '',  $ string);
echo  $ clean_str; // 输出 "HelloWorld12345"

4. 去除中文字符

$ string = "Hello, 世界!";
 $ clean_str = preg_replace('/[x{4e00}-x{9fa5}]/u', '',  $ string);
echo  $ clean_str; // 输出 "Hello, !"

这里的正则表达式/[x{4e00}-x{9fa5}]/u匹配所有中文字符,然后将其替换为空。

猜你喜欢

【PHP】php会出现哪些漏洞呢
会出现的漏洞有跨站脚本攻击、sql注入、文件包含漏洞、代码注入漏洞、文件上传漏洞、会话劫持、不安全的文件权限等等。详细介绍:1、跨站脚本攻击,xss漏洞通常是由于未正确过滤用户输入导致的,为了防止xss漏洞,开发人员应该对用户输入进行严格的过滤和转义,确保用户输入不会被当作脚本执行;2、sql注入,通常是由于未正确过滤用户输入或者使用不安全的sql查询语句导致的等等。本教程操作系统:windows10系统、PHP8.1.3版本、Dell G3电脑。PHP作为一种广泛使用的服务器端脚本语言,被广泛
发表于:2024-03-17 浏览:338 TAG:
【PHP】ThinkPHP6中间件介绍
一、什么是中间件?当客户端发送请求至服务器时,HTTP请求会经过多个中间件,最后返回响应给客户端。中间件可以在请求到达目标控制器或动作之前对请求进行操作可以在响应离开目标控制器或动作之前对响应进行操作二、中间件的作用我们可以在不修改应用程序逻辑的情况下添加额外的功能,如登录验证、检查用户权限、权限控制请求过滤判断当前浏览器环境是在微信或支付宝写系统日志统计三、中间件的类型1、前置中间件前置中间件的意思就是,在http请求完成之前,先执行中间件的代码。一般用来检查用户权限在app/middlewa
发表于:2024-07-29 浏览:260 TAG: #php #thinkphp #中间件
【PHP】PHP设计模式大全与应用场景
面向对象编程的基本原则:1、单一职责:一个类,只需要做好一件事情。2、开放封闭:一个类,应该是可扩展的,而不可修改的。3、依赖倒置:一个类,不应该强依赖另外一个类。每个类对于另外一个类都是可替换的。4、配置化:尽可能的使用配置,而不是硬编码。5、面向接口编程:只需要关心接口,不需要关心实现。1、单例设计模式所谓单例模式,即在应用程序中最多只有该类的一个实例存在,一旦创建,就会一直存在于内存中!单例设计模式常应用于数据库类设计,采用单例模式,只连接一次数据库,防止打开多个数据库连接。一个单例类应具
发表于:2024-06-22 浏览:259 TAG: #php
【PHP】PHP8如何使用Mixed Type处理各种不同类型的数据
PHP8如何使用Mixed Type处理各种不同类型的数据?PHP8是PHP语言的最新版本,引入了许多新的功能和改进。其中一个重要的改进是Mixed Type(混合类型)的引入,它允许开发者在函数参数、返回值和变量声明中处理各种不同类型的数据。在以前的PHP版本中,我们通常使用特定的类型(如int、string、array等)来声明变量、参数和返回值的类型。然而,这种限制有时候会限制我们对数据的处理能力。例如,如果一个函数接受一个数组作为参数,但我们希望还可以传递一个字符串或对象,那么我们需要编
发表于:2023-12-30 浏览:374 TAG:
【PHP】PHP8.1新特性大讲解之initializers初始化器
PHP 8.1:初始化器(new in initializers)PHP 8.1 添加了一个看似很小的细节,但我认为它会对许多人产生重大的日常影响。那么这个“初始化器 RFC 中的新内容”是关于什么的?我们来看一个例子;我们都写过这样的代码:class MyStateMachine {     public function __construct(       &n
发表于:2024-01-04 浏览:320 TAG:
【PHP】中间人攻击是什么,会产生哪些危害,如何有效防止中间人攻击
简介中间人攻击(Man-in-the-Middle Attack,简称MITM攻击)是一种网络攻击,其原理是攻击者通过各种技术手段将受攻击者控制的一台计算机虚拟放置在网络连接中的两台通信计算机之间,这台计算机称为“中间人”。在攻击过程中,中间人可以截取、查看、篡改、伪造或修改受害者之间的通信数据,以达到窃取敏感信息、篡改数据或实施其他恶意行为的目的。举个简单的例子,假设A同学和B同学正在使用一个不安全的公共Wi-Fi网络进行通信,而攻击者恰恰潜伏在这个网络中。A同学想要向B同学发送一条私密信息,
发表于:2024-01-04 浏览:369 TAG:
【PHP】thinkphp5支付宝服务商手机网站支付(新版sdk)
 public function pay() {  Vendor('alipay.wappay.service.AlipayTradeService');         Vendor('alipay.wappay.buildermodel.AlipayTradeWapPayContentBuilder');   &
发表于:2023-12-27 浏览:328 TAG:
【PHP】PHP框架在敏捷开发和大型项目中的应用
hp 框架在敏捷开发和大型项目中应用广泛,提供敏捷性、可扩展性和安全性等优势。例如,在电子商务网站中,laravel 框架可快速创建原型、处理复杂业务逻辑、确保安全和扩展功能。通过利用预定义的组件和设计模式,php 框架为开发人员构建可扩展且维护良好的应用程序提供了便利。PHP框架在敏捷开发和大型项目中的应用PHP框架是用于构建web应用程序的强大工具。它们提供了一套预定义的组件和设计模式,可以简化和加快开发过程。在敏捷开发和大型项目中,使用PHP框架可以带来以下优势:敏捷性:框架允许开发人员
发表于:2024-05-30 浏览:343 TAG:
【PHP】ES在MySQL、PHP中的使用
                                                       ES简介一个高扩展、开源的全文检索和分析引擎,它可以准实时地快速存储、搜索、分析海量的数据。全文检索是指
发表于:2024-06-15 浏览:217 TAG:
【PHP】php解析大量数据json文件方式
1. 在处理超大文件时,我们可以使用逐行读取的方式来解析JSON数据。具体步骤如下:打开文件并逐行读取数据。每次读取一行数据后,使用json_decode()函数将其解析为JSON对象。对解析后的JSON对象进行处理,例如提取需要的数据或进行其他操作。继续读取下一行,重复步骤2和步骤3,直到文件读取完毕。下面是一个示例代码,演示了如何使用以上步骤来解析超大JSON文件:$file = fopen('large_file.json', 'r&#
发表于:2024-08-13 浏览:283 TAG: #php #json