簡體   English   中英

使用正則表達式替換字符串中字符的最后一個實例

[英]Replace last instance of a character in a string using regex

我有一個csv文件,像這樣的數據

Zoos, Sanctuaries & Animal Parks,7469,3.00

不幸的是,這是不正確的,因為第一部分應該是全部這樣的字段

"Zoos, Sanctuaries & Animal Parks","7469","3.00"

由於這只是一次進口,所以我很樂意將其轉換為

Zoos, Sanctuaries & Animal Parks|7469|3.00

最后一個和倒數第二個逗號轉換為管道。 有沒有一種簡單的方法可以用正則表達式來做到這一點?

要將逗號轉換為管道后2個項目,您可以這樣操作

>>> re.sub(",(\d+),([\d.]+)$","|\\1|\\2","Zoos, Sanctuaries & Animal Parks,7469,3.00")
'Zoos, Sanctuaries & Animal Parks|7469|3.00'

這樣的事情應該起作用:

s/(\S),(\S)/\1|\2/g

(用管道將非逗號分隔的兩邊的逗號替換。)

您可以通過這種方式轉換為管道。 只需通過以下命令輸入文本即可:

sed 's/,\([^,]*\),\([^,]*\)$/|\1|\2/'
$ cat test.csv 
Zoos, Sanctuaries & Animal Parks,7469,3.00
a,100,2000
a,b and c, 100,300

$ cat test.csv | perl -npe 's/^(.*),(.*),(.*)$/$1|$2|$3/'
Zoos, Sanctuaries & Animal Parks|7469|3.00
a|100|2000
a,b and c| 100|300

要將最后一個逗號轉換為管道:

$1|$2|$3替換^(.*?),([^,]*?),([^,]*?)$

甚至更好-將它們轉換為正確的格式:

"$1","$2","$3"替換^(.*?),([^,]*?),([^,]*?)$

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM