Ubuntu/Commands/sed

From r00tedvw.com wiki
(Difference between revisions)
Jump to: navigation, search
(Extra)
 
Line 28: Line 28:
 
  perl -wne'while(/[\w\.]+@[\w\.]+/g){print "$&\n"}' test.txt
 
  perl -wne'while(/[\w\.]+@[\w\.]+/g){print "$&\n"}' test.txt
 
The above should find all email addresses within a text file, regardless of where they exist.  It does assume there will be a word boundary before and after the email address.
 
The above should find all email addresses within a text file, regardless of where they exist.  It does assume there will be a word boundary before and after the email address.
 +
<br>
 +
<br>
 +
Add a comma to the end of every line except the last one
 +
<nowiki>sed -i '$!s/$/,/' test.txt</nowiki>
 +
<code>$!</code> means every line except the last.<br>
 +
<code>$</code> matches the end of every line<br>

Latest revision as of 15:07, 13 November 2017

Commands | dig | Mail Server CLI | openssl | sed

Contents

[edit] sed

Sed is a stream editor. A stream editor is used to perform basic text transformations on an input stream (a file or input from a pipeline). While in some ways similar to an editor which permits scripted edits (such as ed), sed works by making only one pass over the input(s), and is consequently more efficient. But it is sed's ability to filter text in a pipeline which particularly distinguishes it from other types of editors.

[edit] Command Syntax

-e
adds a script or regular expression pattern
-i
edits files in place (makes backup if extension supplied)
s/regexp/replacment/
Attempt to match regexp against the pattern space. If successful, replace that portion matched with replacement. The replacement may contain the special character & to refer to that portion of the pattern space which matched, and the special escapes \1 through \9 to refer to the corresponding matching sub-expressions in the regexp.
/g
global, meaning that the match will apply to as many matches on the line as available, instead of just the first

[edit] Examples

Looks for the pattern "Length" and everything after that (greedy match) and replaces it with a whitespace

sed -i 's/Length.*/ /g' TrillianLogFile_Highlighted2.CSV

Inserts a new line after every line into file test

sed -i -e 's/.*/\
&/' test

Append a new line with specific text after every line

sed '/.*/a\test' test

Add new text to the beginning of each line

sed 's/^/| /g' test

[edit] Extra

Finding all email addresses in a text file using Perl. While not related to sed, this is the best section for documentation of it for.

perl -wne'while(/[\w\.]+@[\w\.]+/g){print "$&\n"}' test.txt

The above should find all email addresses within a text file, regardless of where they exist. It does assume there will be a word boundary before and after the email address.

Add a comma to the end of every line except the last one

sed -i '$!s/$/,/' test.txt

$! means every line except the last.
$ matches the end of every line

Personal tools
Namespaces

Variants
Actions
Navigation
Mediawiki
Confluence
DevOps Tools
Open Source Products
Ubuntu
Ubuntu 22
Mac OSX
Oracle Linux
AWS
Windows
OpenVPN
Grafana
InfluxDB2
TrueNas
MagicMirror
OwnCloud
Pivotal
osTicket
OTRS
phpBB
WordPress
VmWare ESXI 5.1
Crypto currencies
HTML
CSS
Python
Java Script
PHP
Raspberry Pi
Canvas LMS
Kaltura Media Server
Plex Media Server
MetaSploit
Zoneminder
ShinobiCE
Photoshop CS2
Fortinet
Uploaded
Certifications
General Info
Games
Meal Plans
NC Statutes
Politics
Volkswagen
Covid
NCDMV
Toolbox