![](/img/trans.png)
[英]How to use Regexp.union to match a character at the beginning of my string
[英]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.