详细介绍Ruby中的正则表达式

Jun 10, 2016 pm 03:15 PM
ruby

正则表达式是一种特殊序列的字符,它通过使用有专门语法的模式来匹配或查找其他字符串或字符串集合。
语法

正则表达式从字面上看是一种介于斜杠之间或介于跟在 %r 后的任意分隔符之间的模式,如下所示:

/pattern/
/pattern/im  # 可以指定选项
%r!/usr/local! # 一般的分隔的正则表达式
实例
#!/usr/bin/ruby
 
line1 = "Cats are smarter than dogs";
line2 = "Dogs also like meat";
 
if ( line1 =~ /Cats(.*)/ )
 puts "Line1 contains Cats"
end
if ( line2 =~ /Cats(.*)/ )
 puts "Line2 contains Dogs"
end
ログイン後にコピー

这将产生以下结果:

Line1 contains Cats
ログイン後にコピー

正则表达式修饰符

正则表达式从字面上看可能包含一个可选的修饰符,用于控制各方面的匹配。修饰符在第二个斜杠字符后指定,如上面实例所示。下标列出了 可能的修饰符:

201541093958504.jpg (982×274)

就像字符串通过 %Q 进行分隔一样,Ruby 允许您以 %r 作为正则表达式的开头,后面跟着任意分隔符。这在描述包含大量您不想转义的斜杠字符时非常有用。

# 下面匹配单个斜杠字符,不转义


%r|/|       
 
# Flag 字符可通过下面的语法进行匹配
%r[</(.*)>]i 

ログイン後にコピー

正则表达式模式

除了控制字符,(+ ? . * ^ $ ( ) [ ] { } | \),其他所有字符都匹配本身。您可以通过在控制字符前放置一个反斜杠来对控制字符进行转义。

下表列出了 Ruby 中可用的正则表达式语法。

201541094045775.jpg (957×701)

201541094114283.jpg (957×731)201541094152882.jpg (956×720)201541094244206.jpg (951×711)201541094311488.jpg (943×723)201541094334570.jpg (964×279)搜索和替换

sub 和 gsub 及它们的替代变量 sub! 和 gsub! 是使用正则表达式时重要的字符串方法。

所有这些方法都是使用正则表达式模式执行搜索与替换操作。sub 和 sub! 替换模式的第一次出现,gsub 和 gsub! 替换模式的所有出现。

sub 和 gsub 返回一个新的字符串,保持原始的字符串不被修改,而 sub! 和 gsub! 则会修改它们调用的字符串。

下面是一个实例:

#!/usr/bin/ruby
 
phone = "2004-959-559 #This is Phone Number"
 
# 删除 Ruby 的注释
phone = phone.sub!(/#.*$/, "") 
puts "Phone Num : #{phone}"
 
# 移除数字以外的其他字符
phone = phone.gsub!(/\D/, "")  
puts "Phone Num : #{phone}"
ログイン後にコピー

这将产生以下结果:

Phone Num : 2004-959-559
Phone Num : 2004959559
ログイン後にコピー

下面是另一个实例:

#!/usr/bin/ruby
 
text = "rails are rails, really good Ruby on Rails"
 
# 把所有的 "rails" 改为 "Rails"
text.gsub!("rails", "Rails")
 
# 把所有的单词 "Rails" 都改成首字母大写
text.gsub!(/\brails\b/, "Rails")
 
puts "#{text}"
ログイン後にコピー

这将产生以下结果:

Rails are Rails, really good Ruby on Rails
ログイン後にコピー

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Golang と Ruby の類似点と相違点の詳細な分析 Golang と Ruby の類似点と相違点の詳細な分析 Jun 01, 2024 pm 08:46 PM

Go と Ruby の主な違いは、Go は軽量な並列処理と効率的なメモリ管理をサポートする静的型付きのコンパイル言語であり、同時実行性の高いアプリケーションの作成に適しているのに対し、Ruby は真の並列処理をサポートする動的型付きのインタープリター言語ですが、メモリ管理がサポートされていないことです。手動制御が必要であり、柔軟な Web アプリケーションの作成に適しています。

Ruby は MySQL を操作するために Mysql2 接続をどのように使用しますか? Ruby は MySQL を操作するために Mysql2 接続をどのように使用しますか? Apr 17, 2023 pm 10:07 PM

Rubyはmysql2を使ってMySQLを操作し、mysqlに接続してmysqlを操作します。 geminstallmysql2 は mysql に接続して接続を確立します: require'mysql2'conn=Mysql2::Client.new({host:'192.168.200.73',username:'root',password:'P@ssword1!'}) 受け入れられた接続オプションには次のものが含まれます: Mysql2::Clie

Python、Ruby、その他の言語でインクリメント演算子が廃止されたのはなぜですか? Python、Ruby、その他の言語でインクリメント演算子が廃止されたのはなぜですか? May 11, 2023 pm 04:37 PM

多くの人は、一部の最新のプログラミング言語 (もちろん、「最近の」プログラミング言語を指すわけではありません) で、インクリメント演算子とデクリメント演算子がキャンセルされているという現象に気づいたかもしれません。言い換えれば、これらの言語には i++ や j-- のような表現はなく、i+=1 または j-=1 のような表現があるだけです。この回答では、この現象の背景と理由を設計哲学の観点から探ります。主流のプログラミング言語の中でインクリメント演算子とデクリメント演算子をサポートしていないのは Python、Rust、Swift だけと思われるため、厳密に言うと「i++ が消滅する」と言うのは偏見かもしれません。私が初めて Python に触れたときも、

MySQLとRubyを使った簡単なデータ変換機能の実装方法 MySQLとRubyを使った簡単なデータ変換機能の実装方法 Sep 21, 2023 am 08:07 AM

MySQLとRubyを使って簡単なデータ変換機能を実装する方法 実際の開発作業では、あるデータ形式を別のデータ形式に変換するデータ変換が必要になることがよくあります。この記事では、MySQL と Ruby を使用して簡単なデータ変換機能を実装する方法と、具体的なコード例を紹介します。まず、MySQL と Ruby 環境をインストールして構成する必要があります。 MySQL データベースがインストールされており、コマンド ラインまたはその他のツールを介してデータベースに接続できることを確認してください。さらに、インストールする必要があります

MySQLとRubyを使った簡単な非同期タスクスケジューリング機能の実装方法 MySQLとRubyを使った簡単な非同期タスクスケジューリング機能の実装方法 Sep 20, 2023 am 10:48 AM

MySQL と Ruby を使用して単純な非同期タスク スケジューリング機能を実装する方法 以前の Web アプリケーションのほとんどは、同期メソッドを使用してリクエストを処理していました。つまり、ユーザーがリクエストを送信した後、サーバーは即座にリクエストを処理し、結果を返します。 。ただし、アプリケーションの複雑さが増すにつれて、同期メソッドの処理効率は徐々に非効率になるため、非同期タスク スケジューリングは、最新の Web アプリケーションでは一般的な要件となっています。この記事では、MySQL と Ruby を使用して、タスクを含む簡単な非同期タスク スケジューリング機能を実装する方法を紹介します。

MySQL と Ruby を使用して簡単なデータクエリと分析機能を実装する方法 MySQL と Ruby を使用して簡単なデータクエリと分析機能を実装する方法 Sep 21, 2023 pm 04:36 PM

MySQL と Ruby を使用して簡単なデータ クエリと分析機能を実装する方法 今日のビッグ データ時代において、データ分析は多くの分野で不可欠な部分となっています。データ分析を実行する場合、最も一般的な操作はデータ クエリです。この記事では、MySQL と Ruby プログラミング言語を使用して簡単なデータ クエリと分析機能を実装する方法を紹介し、具体的なコード例を示します。まず、MySQL と Ruby の開発環境をインストールする必要があります。 MySQL はオープンソースのリレーショナル データベースです。

Ruby 開発における Redis の応用: 複雑なデータ構造をキャッシュする方法 Ruby 開発における Redis の応用: 複雑なデータ構造をキャッシュする方法 Jul 30, 2023 pm 08:58 PM

Ruby 開発における Redis の応用: 複雑なデータ構造をキャッシュする方法 概要: Redis は、データのキャッシュと一時ストレージに広く使用されている高性能のキー/値ストレージ システムです。 Ruby 開発では、Redis を使用して複雑なデータ構造をキャッシュすることで、システムのパフォーマンスと応答速度を向上させることができます。この記事では、Redis を使用して Ruby で複雑なデータ構造をキャッシュする方法を紹介し、コード例を示します。背景: 開発プロセスでは、複雑なデータ構造を処理する必要がある状況に頻繁に遭遇します。例えば、

MySQLとRubyを使って簡単なデータ分析レポート機能を実装する方法 MySQLとRubyを使って簡単なデータ分析レポート機能を実装する方法 Sep 20, 2023 pm 05:09 PM

MySQL と Ruby を使用して簡単なデータ分析レポート機能を実装する方法 はじめに: 今日のデータドリブンの時代において、データ分析は企業の意思決定と開発において重要な役割を果たしています。データ分析の重要な部分であるデータ分析レポートは、データを整理、視覚化、解釈する上で非常に重要です。この記事では、MySQL と Ruby を使用して簡単なデータ分析レポート機能を実装する方法と、対応するコード例を紹介します。 1. データベース設計とテーブル作成はデータ分析とレポート機能を実現する必要がある

See all articles