How to sort by odd lines then remove repeated values?
I have the following type of file:
transcr_25793 +
YAL039C -
transcr_25793 +
YAL037C-B -
transcr_20649 +
YBL100C -
transcr_7135 +
YBL029C-A -
transcr_11317 +
YBL067C -
transcr_25793 +
YAL038W +
transcr_7135 +
YBL029W +
I was trying to get something like this:
transcr_7135 +
YBL029C-A -
transcr_7135 +
YBL029W +
transcr_11317 +
YBL067C -
transcr_20649 +
YBL100C -
transcr_25793 +
YAL039C -
transcr_25793 +
YAL037C-B -
transcr_25793 +
YAL038W +
Then, afterward, I was looking for something like this:
transcr_7135 +
YBL029C-A -
YBL029W +
transcr_11317 +
YBL067C -
transcr_20649 +
YBL100C -
transcr_25793 +
YAL039C -
YAL037C-B -
YAL038W +
I've scrolled through sort
manual and some posts, but couldn't find anything that fit near this, just sort
using numerical values to get odd lines...
text-processing sort
add a comment |
I have the following type of file:
transcr_25793 +
YAL039C -
transcr_25793 +
YAL037C-B -
transcr_20649 +
YBL100C -
transcr_7135 +
YBL029C-A -
transcr_11317 +
YBL067C -
transcr_25793 +
YAL038W +
transcr_7135 +
YBL029W +
I was trying to get something like this:
transcr_7135 +
YBL029C-A -
transcr_7135 +
YBL029W +
transcr_11317 +
YBL067C -
transcr_20649 +
YBL100C -
transcr_25793 +
YAL039C -
transcr_25793 +
YAL037C-B -
transcr_25793 +
YAL038W +
Then, afterward, I was looking for something like this:
transcr_7135 +
YBL029C-A -
YBL029W +
transcr_11317 +
YBL067C -
transcr_20649 +
YBL100C -
transcr_25793 +
YAL039C -
YAL037C-B -
YAL038W +
I've scrolled through sort
manual and some posts, but couldn't find anything that fit near this, just sort
using numerical values to get odd lines...
text-processing sort
add a comment |
I have the following type of file:
transcr_25793 +
YAL039C -
transcr_25793 +
YAL037C-B -
transcr_20649 +
YBL100C -
transcr_7135 +
YBL029C-A -
transcr_11317 +
YBL067C -
transcr_25793 +
YAL038W +
transcr_7135 +
YBL029W +
I was trying to get something like this:
transcr_7135 +
YBL029C-A -
transcr_7135 +
YBL029W +
transcr_11317 +
YBL067C -
transcr_20649 +
YBL100C -
transcr_25793 +
YAL039C -
transcr_25793 +
YAL037C-B -
transcr_25793 +
YAL038W +
Then, afterward, I was looking for something like this:
transcr_7135 +
YBL029C-A -
YBL029W +
transcr_11317 +
YBL067C -
transcr_20649 +
YBL100C -
transcr_25793 +
YAL039C -
YAL037C-B -
YAL038W +
I've scrolled through sort
manual and some posts, but couldn't find anything that fit near this, just sort
using numerical values to get odd lines...
text-processing sort
I have the following type of file:
transcr_25793 +
YAL039C -
transcr_25793 +
YAL037C-B -
transcr_20649 +
YBL100C -
transcr_7135 +
YBL029C-A -
transcr_11317 +
YBL067C -
transcr_25793 +
YAL038W +
transcr_7135 +
YBL029W +
I was trying to get something like this:
transcr_7135 +
YBL029C-A -
transcr_7135 +
YBL029W +
transcr_11317 +
YBL067C -
transcr_20649 +
YBL100C -
transcr_25793 +
YAL039C -
transcr_25793 +
YAL037C-B -
transcr_25793 +
YAL038W +
Then, afterward, I was looking for something like this:
transcr_7135 +
YBL029C-A -
YBL029W +
transcr_11317 +
YBL067C -
transcr_20649 +
YBL100C -
transcr_25793 +
YAL039C -
YAL037C-B -
YAL038W +
I've scrolled through sort
manual and some posts, but couldn't find anything that fit near this, just sort
using numerical values to get odd lines...
text-processing sort
text-processing sort
edited 35 mins ago
Rui F Ribeiro
39.5k1479133
39.5k1479133
asked 2 hours ago
Lucas Farinazzo MarquesLucas Farinazzo Marques
645
645
add a comment |
add a comment |
4 Answers
4
active
oldest
votes
Not exactly the sorting order you've showed, but maby right as well?
$ cat input.txt|paste - -| sort -k1,1V -k2,2| tr "t" "n" | awk '{if($0 in line == 0) {line[$0]; print}}'
transcr_7135 +
YBL029C-A -
YBL029W +
transcr_11317 +
YBL067C -
transcr_20649 +
YBL100C -
transcr_25793 +
YAL037C-B -
YAL038W +
YAL039C -
It doesn't show exactly the way I posted, but for my case it doesn't matter, thanks a lot!
– Lucas Farinazzo Marques
1 hour ago
add a comment |
Pure gawk
solution:
awk -F_ 'NR%2{i=$2;next}{a[i]=a[i]"n"$0}
END{PROCINFO["sorted_in"]="@ind_num_asc";
for(i in a) printf "%s","transcr_"i""a[i]"n"}' file
The trick is to sort indexes of array a
numerically with a little help of gawk
's PROCINFO special array.
transcr_7135
YBL029C-A -
YBL029W +
transcr_11317
YBL067C -
transcr_20649
YBL100C -
transcr_25793
YAL039C -
YAL037C-B -
YAL038W +
BTW, its a pity awk doesn't offer an option to sort naturally a.k.a. version sort (according to text with numbers).
add a comment |
for element in $(sed -n 'p;n' a.txt |sort -nk 1.9 |uniq |awk '{print $1}')
do
echo $element; cat a.txt |grep -A1 $i |grep -v trans |grep -v \\--
done
Where a.txt is your input. Tested:
[root@megatron ~]# cat a.txt
transcr_25793 +
YAL039C -
transcr_25793 +
YAL037C-B -
transcr_20649 +
YBL100C -
transcr_7135 +
YBL029C-A -
transcr_11317 +
YBL067C -
transcr_25793 +
YAL038W +
transcr_7135 +
YBL029W +
[root@megatron ~]# for i in $(sed -n 'p;n' a.txt |sort -nk 1.9 |uniq |awk '{print $1}')
do
echo $i; cat a.txt |grep -A1 $i |grep -v trans |grep -v \\--
done
transcr_7135
YBL029C-A -
YBL029W +
transcr_11317
YBL067C -
transcr_20649
YBL100C -
transcr_25793
YAL039C -
YAL037C-B -
YAL038W +
[root@megatron ~]#
It appeared thistranscr_45 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_193 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_231 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_282 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information.
and so on... Do you know what I can do?
– Lucas Farinazzo Marques
1 hour ago
I corrected. You have to use |grep -v \-- . Or just try to re-use the updated code.
– Zatarra
1 hour ago
Even when exactly copying your solution and even the file with the same name, it doesn't work out... It keeps showing the same error
– Lucas Farinazzo Marques
1 hour ago
You can download it from here: wget 54.38.222.163/sort.sh and run it with sh sort.sh . The text must be in a.txt
– Zatarra
1 hour ago
Now it worked, thanks!
– Lucas Farinazzo Marques
1 hour ago
add a comment |
With GNU sort
and assuming the lines don't contain TAB characters:
paste - - < file | sort -V | tr 't' 'n' | awk '!seen[$0]++'
Or sort -t$'t' -sk1,1V
to preserve the original order for entries with identical odd lines like in your expected output.
If you don't have GNU sort
, and assuming the odd lines always follow that pattern, you can replace sort -V
with sort -k1.9n
.
add a comment |
Your Answer
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "106"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f495272%2fhow-to-sort-by-odd-lines-then-remove-repeated-values%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
4 Answers
4
active
oldest
votes
4 Answers
4
active
oldest
votes
active
oldest
votes
active
oldest
votes
Not exactly the sorting order you've showed, but maby right as well?
$ cat input.txt|paste - -| sort -k1,1V -k2,2| tr "t" "n" | awk '{if($0 in line == 0) {line[$0]; print}}'
transcr_7135 +
YBL029C-A -
YBL029W +
transcr_11317 +
YBL067C -
transcr_20649 +
YBL100C -
transcr_25793 +
YAL037C-B -
YAL038W +
YAL039C -
It doesn't show exactly the way I posted, but for my case it doesn't matter, thanks a lot!
– Lucas Farinazzo Marques
1 hour ago
add a comment |
Not exactly the sorting order you've showed, but maby right as well?
$ cat input.txt|paste - -| sort -k1,1V -k2,2| tr "t" "n" | awk '{if($0 in line == 0) {line[$0]; print}}'
transcr_7135 +
YBL029C-A -
YBL029W +
transcr_11317 +
YBL067C -
transcr_20649 +
YBL100C -
transcr_25793 +
YAL037C-B -
YAL038W +
YAL039C -
It doesn't show exactly the way I posted, but for my case it doesn't matter, thanks a lot!
– Lucas Farinazzo Marques
1 hour ago
add a comment |
Not exactly the sorting order you've showed, but maby right as well?
$ cat input.txt|paste - -| sort -k1,1V -k2,2| tr "t" "n" | awk '{if($0 in line == 0) {line[$0]; print}}'
transcr_7135 +
YBL029C-A -
YBL029W +
transcr_11317 +
YBL067C -
transcr_20649 +
YBL100C -
transcr_25793 +
YAL037C-B -
YAL038W +
YAL039C -
Not exactly the sorting order you've showed, but maby right as well?
$ cat input.txt|paste - -| sort -k1,1V -k2,2| tr "t" "n" | awk '{if($0 in line == 0) {line[$0]; print}}'
transcr_7135 +
YBL029C-A -
YBL029W +
transcr_11317 +
YBL067C -
transcr_20649 +
YBL100C -
transcr_25793 +
YAL037C-B -
YAL038W +
YAL039C -
answered 1 hour ago
finswimmerfinswimmer
1762
1762
It doesn't show exactly the way I posted, but for my case it doesn't matter, thanks a lot!
– Lucas Farinazzo Marques
1 hour ago
add a comment |
It doesn't show exactly the way I posted, but for my case it doesn't matter, thanks a lot!
– Lucas Farinazzo Marques
1 hour ago
It doesn't show exactly the way I posted, but for my case it doesn't matter, thanks a lot!
– Lucas Farinazzo Marques
1 hour ago
It doesn't show exactly the way I posted, but for my case it doesn't matter, thanks a lot!
– Lucas Farinazzo Marques
1 hour ago
add a comment |
Pure gawk
solution:
awk -F_ 'NR%2{i=$2;next}{a[i]=a[i]"n"$0}
END{PROCINFO["sorted_in"]="@ind_num_asc";
for(i in a) printf "%s","transcr_"i""a[i]"n"}' file
The trick is to sort indexes of array a
numerically with a little help of gawk
's PROCINFO special array.
transcr_7135
YBL029C-A -
YBL029W +
transcr_11317
YBL067C -
transcr_20649
YBL100C -
transcr_25793
YAL039C -
YAL037C-B -
YAL038W +
BTW, its a pity awk doesn't offer an option to sort naturally a.k.a. version sort (according to text with numbers).
add a comment |
Pure gawk
solution:
awk -F_ 'NR%2{i=$2;next}{a[i]=a[i]"n"$0}
END{PROCINFO["sorted_in"]="@ind_num_asc";
for(i in a) printf "%s","transcr_"i""a[i]"n"}' file
The trick is to sort indexes of array a
numerically with a little help of gawk
's PROCINFO special array.
transcr_7135
YBL029C-A -
YBL029W +
transcr_11317
YBL067C -
transcr_20649
YBL100C -
transcr_25793
YAL039C -
YAL037C-B -
YAL038W +
BTW, its a pity awk doesn't offer an option to sort naturally a.k.a. version sort (according to text with numbers).
add a comment |
Pure gawk
solution:
awk -F_ 'NR%2{i=$2;next}{a[i]=a[i]"n"$0}
END{PROCINFO["sorted_in"]="@ind_num_asc";
for(i in a) printf "%s","transcr_"i""a[i]"n"}' file
The trick is to sort indexes of array a
numerically with a little help of gawk
's PROCINFO special array.
transcr_7135
YBL029C-A -
YBL029W +
transcr_11317
YBL067C -
transcr_20649
YBL100C -
transcr_25793
YAL039C -
YAL037C-B -
YAL038W +
BTW, its a pity awk doesn't offer an option to sort naturally a.k.a. version sort (according to text with numbers).
Pure gawk
solution:
awk -F_ 'NR%2{i=$2;next}{a[i]=a[i]"n"$0}
END{PROCINFO["sorted_in"]="@ind_num_asc";
for(i in a) printf "%s","transcr_"i""a[i]"n"}' file
The trick is to sort indexes of array a
numerically with a little help of gawk
's PROCINFO special array.
transcr_7135
YBL029C-A -
YBL029W +
transcr_11317
YBL067C -
transcr_20649
YBL100C -
transcr_25793
YAL039C -
YAL037C-B -
YAL038W +
BTW, its a pity awk doesn't offer an option to sort naturally a.k.a. version sort (according to text with numbers).
edited 22 mins ago
answered 1 hour ago
jimmijjimmij
31k870105
31k870105
add a comment |
add a comment |
for element in $(sed -n 'p;n' a.txt |sort -nk 1.9 |uniq |awk '{print $1}')
do
echo $element; cat a.txt |grep -A1 $i |grep -v trans |grep -v \\--
done
Where a.txt is your input. Tested:
[root@megatron ~]# cat a.txt
transcr_25793 +
YAL039C -
transcr_25793 +
YAL037C-B -
transcr_20649 +
YBL100C -
transcr_7135 +
YBL029C-A -
transcr_11317 +
YBL067C -
transcr_25793 +
YAL038W +
transcr_7135 +
YBL029W +
[root@megatron ~]# for i in $(sed -n 'p;n' a.txt |sort -nk 1.9 |uniq |awk '{print $1}')
do
echo $i; cat a.txt |grep -A1 $i |grep -v trans |grep -v \\--
done
transcr_7135
YBL029C-A -
YBL029W +
transcr_11317
YBL067C -
transcr_20649
YBL100C -
transcr_25793
YAL039C -
YAL037C-B -
YAL038W +
[root@megatron ~]#
It appeared thistranscr_45 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_193 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_231 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_282 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information.
and so on... Do you know what I can do?
– Lucas Farinazzo Marques
1 hour ago
I corrected. You have to use |grep -v \-- . Or just try to re-use the updated code.
– Zatarra
1 hour ago
Even when exactly copying your solution and even the file with the same name, it doesn't work out... It keeps showing the same error
– Lucas Farinazzo Marques
1 hour ago
You can download it from here: wget 54.38.222.163/sort.sh and run it with sh sort.sh . The text must be in a.txt
– Zatarra
1 hour ago
Now it worked, thanks!
– Lucas Farinazzo Marques
1 hour ago
add a comment |
for element in $(sed -n 'p;n' a.txt |sort -nk 1.9 |uniq |awk '{print $1}')
do
echo $element; cat a.txt |grep -A1 $i |grep -v trans |grep -v \\--
done
Where a.txt is your input. Tested:
[root@megatron ~]# cat a.txt
transcr_25793 +
YAL039C -
transcr_25793 +
YAL037C-B -
transcr_20649 +
YBL100C -
transcr_7135 +
YBL029C-A -
transcr_11317 +
YBL067C -
transcr_25793 +
YAL038W +
transcr_7135 +
YBL029W +
[root@megatron ~]# for i in $(sed -n 'p;n' a.txt |sort -nk 1.9 |uniq |awk '{print $1}')
do
echo $i; cat a.txt |grep -A1 $i |grep -v trans |grep -v \\--
done
transcr_7135
YBL029C-A -
YBL029W +
transcr_11317
YBL067C -
transcr_20649
YBL100C -
transcr_25793
YAL039C -
YAL037C-B -
YAL038W +
[root@megatron ~]#
It appeared thistranscr_45 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_193 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_231 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_282 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information.
and so on... Do you know what I can do?
– Lucas Farinazzo Marques
1 hour ago
I corrected. You have to use |grep -v \-- . Or just try to re-use the updated code.
– Zatarra
1 hour ago
Even when exactly copying your solution and even the file with the same name, it doesn't work out... It keeps showing the same error
– Lucas Farinazzo Marques
1 hour ago
You can download it from here: wget 54.38.222.163/sort.sh and run it with sh sort.sh . The text must be in a.txt
– Zatarra
1 hour ago
Now it worked, thanks!
– Lucas Farinazzo Marques
1 hour ago
add a comment |
for element in $(sed -n 'p;n' a.txt |sort -nk 1.9 |uniq |awk '{print $1}')
do
echo $element; cat a.txt |grep -A1 $i |grep -v trans |grep -v \\--
done
Where a.txt is your input. Tested:
[root@megatron ~]# cat a.txt
transcr_25793 +
YAL039C -
transcr_25793 +
YAL037C-B -
transcr_20649 +
YBL100C -
transcr_7135 +
YBL029C-A -
transcr_11317 +
YBL067C -
transcr_25793 +
YAL038W +
transcr_7135 +
YBL029W +
[root@megatron ~]# for i in $(sed -n 'p;n' a.txt |sort -nk 1.9 |uniq |awk '{print $1}')
do
echo $i; cat a.txt |grep -A1 $i |grep -v trans |grep -v \\--
done
transcr_7135
YBL029C-A -
YBL029W +
transcr_11317
YBL067C -
transcr_20649
YBL100C -
transcr_25793
YAL039C -
YAL037C-B -
YAL038W +
[root@megatron ~]#
for element in $(sed -n 'p;n' a.txt |sort -nk 1.9 |uniq |awk '{print $1}')
do
echo $element; cat a.txt |grep -A1 $i |grep -v trans |grep -v \\--
done
Where a.txt is your input. Tested:
[root@megatron ~]# cat a.txt
transcr_25793 +
YAL039C -
transcr_25793 +
YAL037C-B -
transcr_20649 +
YBL100C -
transcr_7135 +
YBL029C-A -
transcr_11317 +
YBL067C -
transcr_25793 +
YAL038W +
transcr_7135 +
YBL029W +
[root@megatron ~]# for i in $(sed -n 'p;n' a.txt |sort -nk 1.9 |uniq |awk '{print $1}')
do
echo $i; cat a.txt |grep -A1 $i |grep -v trans |grep -v \\--
done
transcr_7135
YBL029C-A -
YBL029W +
transcr_11317
YBL067C -
transcr_20649
YBL100C -
transcr_25793
YAL039C -
YAL037C-B -
YAL038W +
[root@megatron ~]#
edited 1 hour ago
andcoz
12.5k33039
12.5k33039
answered 2 hours ago
ZatarraZatarra
212
212
It appeared thistranscr_45 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_193 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_231 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_282 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information.
and so on... Do you know what I can do?
– Lucas Farinazzo Marques
1 hour ago
I corrected. You have to use |grep -v \-- . Or just try to re-use the updated code.
– Zatarra
1 hour ago
Even when exactly copying your solution and even the file with the same name, it doesn't work out... It keeps showing the same error
– Lucas Farinazzo Marques
1 hour ago
You can download it from here: wget 54.38.222.163/sort.sh and run it with sh sort.sh . The text must be in a.txt
– Zatarra
1 hour ago
Now it worked, thanks!
– Lucas Farinazzo Marques
1 hour ago
add a comment |
It appeared thistranscr_45 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_193 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_231 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_282 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information.
and so on... Do you know what I can do?
– Lucas Farinazzo Marques
1 hour ago
I corrected. You have to use |grep -v \-- . Or just try to re-use the updated code.
– Zatarra
1 hour ago
Even when exactly copying your solution and even the file with the same name, it doesn't work out... It keeps showing the same error
– Lucas Farinazzo Marques
1 hour ago
You can download it from here: wget 54.38.222.163/sort.sh and run it with sh sort.sh . The text must be in a.txt
– Zatarra
1 hour ago
Now it worked, thanks!
– Lucas Farinazzo Marques
1 hour ago
It appeared this
transcr_45 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_193 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_231 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_282 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information.
and so on... Do you know what I can do?– Lucas Farinazzo Marques
1 hour ago
It appeared this
transcr_45 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_193 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_231 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information. transcr_282 Usage: grep [OPTION]... PATTERN [FILE]... Try 'grep --help' for more information.
and so on... Do you know what I can do?– Lucas Farinazzo Marques
1 hour ago
I corrected. You have to use |grep -v \-- . Or just try to re-use the updated code.
– Zatarra
1 hour ago
I corrected. You have to use |grep -v \-- . Or just try to re-use the updated code.
– Zatarra
1 hour ago
Even when exactly copying your solution and even the file with the same name, it doesn't work out... It keeps showing the same error
– Lucas Farinazzo Marques
1 hour ago
Even when exactly copying your solution and even the file with the same name, it doesn't work out... It keeps showing the same error
– Lucas Farinazzo Marques
1 hour ago
You can download it from here: wget 54.38.222.163/sort.sh and run it with sh sort.sh . The text must be in a.txt
– Zatarra
1 hour ago
You can download it from here: wget 54.38.222.163/sort.sh and run it with sh sort.sh . The text must be in a.txt
– Zatarra
1 hour ago
Now it worked, thanks!
– Lucas Farinazzo Marques
1 hour ago
Now it worked, thanks!
– Lucas Farinazzo Marques
1 hour ago
add a comment |
With GNU sort
and assuming the lines don't contain TAB characters:
paste - - < file | sort -V | tr 't' 'n' | awk '!seen[$0]++'
Or sort -t$'t' -sk1,1V
to preserve the original order for entries with identical odd lines like in your expected output.
If you don't have GNU sort
, and assuming the odd lines always follow that pattern, you can replace sort -V
with sort -k1.9n
.
add a comment |
With GNU sort
and assuming the lines don't contain TAB characters:
paste - - < file | sort -V | tr 't' 'n' | awk '!seen[$0]++'
Or sort -t$'t' -sk1,1V
to preserve the original order for entries with identical odd lines like in your expected output.
If you don't have GNU sort
, and assuming the odd lines always follow that pattern, you can replace sort -V
with sort -k1.9n
.
add a comment |
With GNU sort
and assuming the lines don't contain TAB characters:
paste - - < file | sort -V | tr 't' 'n' | awk '!seen[$0]++'
Or sort -t$'t' -sk1,1V
to preserve the original order for entries with identical odd lines like in your expected output.
If you don't have GNU sort
, and assuming the odd lines always follow that pattern, you can replace sort -V
with sort -k1.9n
.
With GNU sort
and assuming the lines don't contain TAB characters:
paste - - < file | sort -V | tr 't' 'n' | awk '!seen[$0]++'
Or sort -t$'t' -sk1,1V
to preserve the original order for entries with identical odd lines like in your expected output.
If you don't have GNU sort
, and assuming the odd lines always follow that pattern, you can replace sort -V
with sort -k1.9n
.
edited 1 hour ago
answered 1 hour ago
Stéphane ChazelasStéphane Chazelas
301k55564916
301k55564916
add a comment |
add a comment |
Thanks for contributing an answer to Unix & Linux Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f495272%2fhow-to-sort-by-odd-lines-then-remove-repeated-values%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown