繁体   English   中英

正则表达式以匹配以“ @”字符为前缀的用户名

[英]Regexp to match usernames prefixed by “@” character

我正在尝试编写一个方法,该方法采用通过以下格式的表单输入的字符串:

string = "@user1, @user2, @user3"

并返回类似['user1', 'user2', 'user3']的数组。

这是我到目前为止的内容:

usernames = "@user1, @user2"

temp_recipient_usernames = usernames.split(',')
recipient_usernames = temp_recipient_usernames.each do |u|
  u.gsub /@(\w+)/ do |username|
    @final_usernames = username.gsub('@', '')
  end
end

p @final_usernames

这仅返回字符串"user2" 我该如何工作?

您正在重新设计轮子,这里的String#scan方法正是出于您的目的:

usernames = "@user1, @user2"
usernames.scan(/(?<=@)\w+/)
# => ["user1", "user2"]

更新 :假设usernames字符串始终具有您描述的确切格式,即它仅包含@前缀的使用名,逗号和空格; 可以将regexp简化一些:

usernames.scan(/\w+/)
# => ["user1", "user2"]

这不是最短的方法,但是在概念上很简单。

"@user1, @user2, @user3"
.split(", ")
.map{|s| s.delete("@")}
# => ["user1", "user2", "user3"]

要么,

"@user1, @user2, @user3"
.delete("@")
.split(", ")
# => ["user1", "user2", "user3"]

其他方式 :

usernames = "@user1, @user2"
usernames.split(/\W/).reject(&:empty?) # => ["user1", "user2"]

或者这个:

"@user1, @user2, @user3".gsub("@","").split(",")
#=> ["user1", " user2", " user3"]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM