Identical strings in column
-
Given your answers, and the very different data, which takes a completely differnt regex than I was expecting:
- Duplicate the 32char alphanumeric to the start of line:
- FIND =
(?-s)(?=^.*\t([[:alnum:]]{32})\t)
REPLACE =$1\x20\x20\x20\x20\x20$0
MODE = regular expression
Replace All
- FIND =
- Sort:
- Select all but the first (header) line
- Edit > Line Operations > Sort Lines Lexicographically Ascending
- check for duplicates and mark with ✗
- FIND =
(?-s)^([[:alnum:]]{32})..\x20{3}(.*\R)^\1..\x20{3}
REPLACE =$1\x20✗\x20\x20\x20$2$1\x20✗\x20\x20\x20
MODE = regular expression
Replace All
- FIND =
- Manually check and delete:
- FIND =
(?-s)^([[:alnum:]]{32})\x20✗\x20{3}.*(\R|\z)
REPLACE = leave empty
MODE = Regular expression
Find Next, and Replace on the ones you want to delete; or Replace All if you’ve verified all are okay to delete
- FIND =
- Clean out extra column at the beginning
- FIND =
(?-s)^([[:alnum:]]{32})\x20.\x20{3}
REPLACE = leave empty
MODE = Regular expression
Replace All
- FIND =
- Sort:
- Select all but the first (header) line
- Edit > Line Operations > Sort Lines Lexicographically Ascending
(I use \x20 throughout to indicate a space, both in the search and in the replace expressions. That way, there is no ambiguity)
(@guy038 , @Alan-Kilborn , @astrosofista : by grabbing a copy of the 32-char field at the beginning, and using spaces to separate, I ignored the problem of the tab-sorting, and eliminated the need to do a column-select for a sort. it made it much easier to implement and explain)
@Petr-Jaja ,I think this does it for you. Notice that I ignored which column number the 32 alpha-numeric sequence is in, as long as it has a tab before and after. This matches the data you showed (which had only one field that was 32 characters exactly), but might not match reality. The answers you get are only as good as the data you give.
caveat emptor
This sequence seemed to work for me, based on my understanding of your issue, and is published here to help you learn how to do this. I make no guarantees or warranties as to the functionality for you. You are responsible to save and backup all data before and after running this sequence.
- Duplicate the 32char alphanumeric to the start of line:
-
Hello, @petr-jaja, @peterjones, @astrosofista, @alan-kilborn and All,
Well, it’s going worse than I initially thought ! And the @alan-kilborn’s assumptions are certainly true, as well !
First, for nice testing, you must use, at least, the
v7.9
release, which corrects some sorting problems ( but not all, apparently ! ) when using thecolumn mode
selection !So, let’s consider this initial text, below, where I changed the last char of the string
013300000001
, beginning the linesI used, alternatively, in an
UTF-8
encoded file :-
The character
1
, coded inUTF-8
, with one byte (31
) -
The character
é
, coded inUTF-8
, with two bytes (C3A9
) -
The character
∑
, coded inUTF-8
, with three bytes (E28891
) -
The character
🦅
, coded inUTF-8
, with four bytes (F09FA685
)
01330000000🦅 A7615A4D1AD8C62E8C51DB0AD65185F2 0126CDD833FFFFFF 01330000000é 0316C2C8995F3578FC049D93F6087B75 0126CA6F33FFFFFF 01330000000∑ 12CD01162A78F3D098AE55D134F10C0D 0126C88B33FFFFFF 013300000001 FB5982FE17A6B421D89F2C1C3754AB6C 0126CBD133FFFFFF 01330000000é C8777C86BC654A5B55062F9F126E963C 0126CA6533FFFFFF 013300000001 C8777C86BC654A5B55062F9F126E963C 0126CA6533FFFFFF 01330000000∑ 09AD9E8A84D78DB0FBBAF2B3B22AC04F 0126CDE433FFFFFF 01330000000🦅 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF 01330000000é E837148B8421B897B4EA8176B631E204 0126CDDC33FFFFFF 01330000000∑ 7EB122DDF2B374AE7CDBF2BF473A1D9A 0126CE4C33FFFFFF 01330000000🦅 B710ABACD63738BF951175D2FDDDE926 0126CDF533FFFFFF 013300000001 A7615A4D1AD8C62E8C51DB0AD65185F2 0126CDD833FFFFFF 01330000000é 1C372C66D8F7B88632648FB6C309E207 0126C88F33FFFFFF 013300000001 8746F0EE21B33577748181E4B4081AC5 0126CA6633FFFFFF 01330000000∑ D90B687CC72FC14D9368CEE2F64569D0 0126CCF333FFFFFF 013300000001 E2E65364C81552F7DCAAECA3F16A0E30 0126CCE333FFFFFF 01330000000é A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF 01330000000🦅 04F68F6226AA322414B35E481A844CF1 0126CB7B33FFFFFF 013300000001 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF
With the
v7.9.2
release, after doing a zero-length column-mode selection, at column17
, right before theMD5
checksums, through all the lines and running a usualSort Lines Lexicographically Ascending
, I got this text :01330000000🦅 04F68F6226AA322414B35E481A844CF1 0126CB7B33FFFFFF 01330000000🦅 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF 01330000000🦅 A7615A4D1AD8C62E8C51DB0AD65185F2 0126CDD833FFFFFF 01330000000🦅 B710ABACD63738BF951175D2FDDDE926 0126CDF533FFFFFF 01330000000é 0316C2C8995F3578FC049D93F6087B75 0126CA6F33FFFFFF 01330000000∑ 09AD9E8A84D78DB0FBBAF2B3B22AC04F 0126CDE433FFFFFF 01330000000∑ 12CD01162A78F3D098AE55D134F10C0D 0126C88B33FFFFFF 01330000000é 1C372C66D8F7B88632648FB6C309E207 0126C88F33FFFFFF 01330000000∑ 7EB122DDF2B374AE7CDBF2BF473A1D9A 0126CE4C33FFFFFF 013300000001 8746F0EE21B33577748181E4B4081AC5 0126CA6633FFFFFF 01330000000é A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF 013300000001 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF 013300000001 A7615A4D1AD8C62E8C51DB0AD65185F2 0126CDD833FFFFFF 01330000000é C8777C86BC654A5B55062F9F126E963C 0126CA6533FFFFFF 013300000001 C8777C86BC654A5B55062F9F126E963C 0126CA6533FFFFFF 01330000000∑ D90B687CC72FC14D9368CEE2F64569D0 0126CCF333FFFFFF 013300000001 E2E65364C81552F7DCAAECA3F16A0E30 0126CCE333FFFFFF 01330000000é E837148B8421B897B4EA8176B631E204 0126CDDC33FFFFFF 013300000001 FB5982FE17A6B421D89F2C1C3754AB6C 0126CBD133FFFFFF
As you can see, the
MD5
strings seem to be sorted in two distinct ranges :-
A first block of lines, containing the character with Unicode code-point over
U+FFFF
-
A second block of lines, containing, only, characters with Unicode code-point under
U+10000
Again, I verified that, if I inserted these same characters, instead of the first char of the
0126...
string, so after theMD5
values to sort, the bug does not occur and theMD5
checksums are correctly sorted !So, guys, I’ll probably create an issue, after your possible replies !
Best Regards,
guy038
-
-
Here’s a series of screenshots for the 6 steps, showing it in action
-
Hello, @petr-jaja, @peterjones, @astrosofista, @alan-kilborn and All,
I think that a solution, in fewer steps, should be possible !
Let’s start with the initial example of @petr-jaja, in this post :
https://community.notepad-plus-plus.org/post/63869
First, like @peterjones said, we copy the
MD5
checksums at beginning of each line :-
SEARCH
(?-s)^.+\t([[:xdigit:]]{32})\t
-
REPLACE
\1\t$0
So, we get this text :
Product Date/Time C T H Test Field Test Device Serial No Sensor Serial Software Version Battery Code Order No Inspector A7615A4D1AD8C62E8C51DB0AD65185F2 metalo 2021-03-09T14:21:17.600361 0 SUCCESS 013300000001 A7615A4D1AD8C62E8C51DB0AD65185F2 0126CDD833FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) 0316C2C8995F3578FC049D93F6087B75 metalo 2021-03-09T14:21:30.437178 0 SUCCESS 013300000001 0316C2C8995F3578FC049D93F6087B75 0126CA6F33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) 12CD01162A78F3D098AE55D134F10C0D metalo 2021-03-09T14:21:44.398500 0 SUCCESS 013300000001 12CD01162A78F3D098AE55D134F10C0D 0126C88B33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) FB5982FE17A6B421D89F2C1C3754AB6C metalo 2021-03-09T14:21:53.262360 0 SUCCESS 013300000001 FB5982FE17A6B421D89F2C1C3754AB6C 0126CBD133FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) C8777C86BC654A5B55062F9F126E963C metalo 2021-03-09T14:22:09.373559 0 FAILED 013300000001 C8777C86BC654A5B55062F9F126E963C 0126CA6533FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) C8777C86BC654A5B55062F9F126E963C metalo 2021-03-09T14:22:23.436083 0 SUCCESS 013300000001 C8777C86BC654A5B55062F9F126E963C 0126CA6533FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) 09AD9E8A84D78DB0FBBAF2B3B22AC04F metalo 2021-03-09T14:22:34.567201 0 SUCCESS 013300000001 09AD9E8A84D78DB0FBBAF2B3B22AC04F 0126CDE433FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) A670A18BC7CEEC1562219ABA149DA153 metalo 2021-03-09T14:23:24.688700 0 SUCCESS 013300000001 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) E837148B8421B897B4EA8176B631E204 metalo 2021-03-09T14:23:54.831355 0 SUCCESS 013300000001 E837148B8421B897B4EA8176B631E204 0126CDDC33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) 7EB122DDF2B374AE7CDBF2BF473A1D9A metalo 2021-03-09T14:24:11.763923 0 SUCCESS 013300000001 7EB122DDF2B374AE7CDBF2BF473A1D9A 0126CE4C33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) B710ABACD63738BF951175D2FDDDE926 metalo 2021-03-09T14:24:23.617504 0 SUCCESS 013300000001 B710ABACD63738BF951175D2FDDDE926 0126CDF533FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) A7615A4D1AD8C62E8C51DB0AD65185F2 metalo 2021-03-09T14:24:36.528950 0 SUCCESS 013300000001 A7615A4D1AD8C62E8C51DB0AD65185F2 0126CDD833FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) 1C372C66D8F7B88632648FB6C309E207 metalo 2021-03-09T14:24:50.557704 0 SUCCESS 013300000001 1C372C66D8F7B88632648FB6C309E207 0126C88F33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) 8746F0EE21B33577748181E4B4081AC5 metalo 2021-03-09T14:25:04.470269 0 SUCCESS 013300000001 8746F0EE21B33577748181E4B4081AC5 0126CA6633FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) D90B687CC72FC14D9368CEE2F64569D0 metalo 2021-03-09T14:25:20.594258 0 SUCCESS 013300000001 D90B687CC72FC14D9368CEE2F64569D0 0126CCF333FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) E2E65364C81552F7DCAAECA3F16A0E30 metalo 2021-03-09T14:25:48.726621 0 SUCCESS 013300000001 E2E65364C81552F7DCAAECA3F16A0E30 0126CCE333FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) A670A18BC7CEEC1562219ABA149DA153 metalo 2021-03-09T14:26:00.645561 0 FAILED 013300000001 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) 04F68F6226AA322414B35E481A844CF1 metalo 2021-03-09T14:26:12.536780 0 SUCCESS 013300000001 04F68F6226AA322414B35E481A844CF1 0126CB7B33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) A670A18BC7CEEC1562219ABA149DA153 metalo 2021-03-09T14:26:24.438022 0 SUCCESS 013300000001 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1)
Then, select all lines, but the first header line and sort lines with the
Edit > Line Operations > Sort Lines Lexicographically Ascending
menu commandWe get :
Product Date/Time C T H Test Field Test Device Serial No Sensor Serial Software Version Battery Code Order No Inspector 0316C2C8995F3578FC049D93F6087B75 metalo 2021-03-09T14:21:30.437178 0 SUCCESS 013300000001 0316C2C8995F3578FC049D93F6087B75 0126CA6F33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) 04F68F6226AA322414B35E481A844CF1 metalo 2021-03-09T14:26:12.536780 0 SUCCESS 013300000001 04F68F6226AA322414B35E481A844CF1 0126CB7B33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) 09AD9E8A84D78DB0FBBAF2B3B22AC04F metalo 2021-03-09T14:22:34.567201 0 SUCCESS 013300000001 09AD9E8A84D78DB0FBBAF2B3B22AC04F 0126CDE433FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) 12CD01162A78F3D098AE55D134F10C0D metalo 2021-03-09T14:21:44.398500 0 SUCCESS 013300000001 12CD01162A78F3D098AE55D134F10C0D 0126C88B33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) 1C372C66D8F7B88632648FB6C309E207 metalo 2021-03-09T14:24:50.557704 0 SUCCESS 013300000001 1C372C66D8F7B88632648FB6C309E207 0126C88F33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) 7EB122DDF2B374AE7CDBF2BF473A1D9A metalo 2021-03-09T14:24:11.763923 0 SUCCESS 013300000001 7EB122DDF2B374AE7CDBF2BF473A1D9A 0126CE4C33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) 8746F0EE21B33577748181E4B4081AC5 metalo 2021-03-09T14:25:04.470269 0 SUCCESS 013300000001 8746F0EE21B33577748181E4B4081AC5 0126CA6633FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) A670A18BC7CEEC1562219ABA149DA153 metalo 2021-03-09T14:23:24.688700 0 SUCCESS 013300000001 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) A670A18BC7CEEC1562219ABA149DA153 metalo 2021-03-09T14:26:00.645561 0 FAILED 013300000001 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) A670A18BC7CEEC1562219ABA149DA153 metalo 2021-03-09T14:26:24.438022 0 SUCCESS 013300000001 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) A7615A4D1AD8C62E8C51DB0AD65185F2 metalo 2021-03-09T14:21:17.600361 0 SUCCESS 013300000001 A7615A4D1AD8C62E8C51DB0AD65185F2 0126CDD833FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) A7615A4D1AD8C62E8C51DB0AD65185F2 metalo 2021-03-09T14:24:36.528950 0 SUCCESS 013300000001 A7615A4D1AD8C62E8C51DB0AD65185F2 0126CDD833FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) B710ABACD63738BF951175D2FDDDE926 metalo 2021-03-09T14:24:23.617504 0 SUCCESS 013300000001 B710ABACD63738BF951175D2FDDDE926 0126CDF533FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) C8777C86BC654A5B55062F9F126E963C metalo 2021-03-09T14:22:09.373559 0 FAILED 013300000001 C8777C86BC654A5B55062F9F126E963C 0126CA6533FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) C8777C86BC654A5B55062F9F126E963C metalo 2021-03-09T14:22:23.436083 0 SUCCESS 013300000001 C8777C86BC654A5B55062F9F126E963C 0126CA6533FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) D90B687CC72FC14D9368CEE2F64569D0 metalo 2021-03-09T14:25:20.594258 0 SUCCESS 013300000001 D90B687CC72FC14D9368CEE2F64569D0 0126CCF333FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) E2E65364C81552F7DCAAECA3F16A0E30 metalo 2021-03-09T14:25:48.726621 0 SUCCESS 013300000001 E2E65364C81552F7DCAAECA3F16A0E30 0126CCE333FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) E837148B8421B897B4EA8176B631E204 metalo 2021-03-09T14:23:54.831355 0 SUCCESS 013300000001 E837148B8421B897B4EA8176B631E204 0126CDDC33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) FB5982FE17A6B421D89F2C1C3754AB6C metalo 2021-03-09T14:21:53.262360 0 SUCCESS 013300000001 FB5982FE17A6B421D89F2C1C3754AB6C 0126CBD133FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1)
Now, three options are possible :
-
You would like to get an idea of the different duplicate
MD5
strings and lines which need future deletion ( option A ) -
You would like to delete the duplicate
MD5
strings, one at a time, with theReplace
button ( Option B ) -
You are rather confident about all the replacements to achieve . For instance, you have made a backup of your file ! ( Option C )
Whatever the option chosen, remember to :
-
Tick the
Wrap around
option -
Select the
Regular expression
search mode
-
Option A :
-
Open the Mark dialog (
Ctrl + M
)-
SEARCH
(?-s)^.*([[:xdigit:]]{32}).*\R(?:.*\1.*\R)+
-
Tick the
Bookmark line
option -
Click on the
Mark All
button -
Note that using the
Search > Bookmark > Remove Bookmarked Lines
option, you can also delete all the lines with duplicateMD5
strings !
-
-
-
Option B :
-
Open the Replace dialog (
Ctrl + H
)-
SEARCH
(?-s)^.*([[:xdigit:]]{32}).*\R(?:.*\1.*\R)+
-
REPLACE
Leave EMPTY
-
Click several times on the
Replace
button to delete the first duplicate blocks of lines -
If everything seems OK, you may click once on the
Replace All
button
-
-
After deletion of the lines with duplicates, with the options A or B, uses the following regex S/R to get rid of the temporary
MD5
strings at beginning of lines ;:-
SEARCH
(?-i)^(?!Product).+?\t(.)
-
REPLACE
\1
-
-
-
Option C :
-
Open the Replace dialog (
Ctrl + H
)-
SEARCH
(?-is)^.*([[:xdigit:]]{32}).*\R(?:.*\1.*\R)+|^(?!Product).+?\t(.)
-
REPLACE
?2\2
-
Click, just once, on the
Replace All
button
-
-
Whatever the option A, B, or C used, we obtain that text :
Product Date/Time C T H Test Field Test Device Serial No Sensor Serial Software Version Battery Code Order No Inspector metalo 2021-03-09T14:21:30.437178 0 SUCCESS 013300000001 0316C2C8995F3578FC049D93F6087B75 0126CA6F33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:26:12.536780 0 SUCCESS 013300000001 04F68F6226AA322414B35E481A844CF1 0126CB7B33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:22:34.567201 0 SUCCESS 013300000001 09AD9E8A84D78DB0FBBAF2B3B22AC04F 0126CDE433FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:21:44.398500 0 SUCCESS 013300000001 12CD01162A78F3D098AE55D134F10C0D 0126C88B33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:24:50.557704 0 SUCCESS 013300000001 1C372C66D8F7B88632648FB6C309E207 0126C88F33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:24:11.763923 0 SUCCESS 013300000001 7EB122DDF2B374AE7CDBF2BF473A1D9A 0126CE4C33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:25:04.470269 0 SUCCESS 013300000001 8746F0EE21B33577748181E4B4081AC5 0126CA6633FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:24:23.617504 0 SUCCESS 013300000001 B710ABACD63738BF951175D2FDDDE926 0126CDF533FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:25:20.594258 0 SUCCESS 013300000001 D90B687CC72FC14D9368CEE2F64569D0 0126CCF333FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:25:48.726621 0 SUCCESS 013300000001 E2E65364C81552F7DCAAECA3F16A0E30 0126CCE333FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:23:54.831355 0 SUCCESS 013300000001 E837148B8421B897B4EA8176B631E204 0126CDDC33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:21:53.262360 0 SUCCESS 013300000001 FB5982FE17A6B421D89F2C1C3754AB6C 0126CBD133FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1)
Finally, select all lines, but the first header line, again and sort the lines with the
Edit > Line Operations > Sort Lines Lexicographically Ascending
menu commandYou should get your expected output :
Product Date/Time C T H Test Field Test Device Serial No Sensor Serial Software Version Battery Code Order No Inspector metalo 2021-03-09T14:21:30.437178 0 SUCCESS 013300000001 0316C2C8995F3578FC049D93F6087B75 0126CA6F33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:21:44.398500 0 SUCCESS 013300000001 12CD01162A78F3D098AE55D134F10C0D 0126C88B33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:21:53.262360 0 SUCCESS 013300000001 FB5982FE17A6B421D89F2C1C3754AB6C 0126CBD133FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:22:34.567201 0 SUCCESS 013300000001 09AD9E8A84D78DB0FBBAF2B3B22AC04F 0126CDE433FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:23:54.831355 0 SUCCESS 013300000001 E837148B8421B897B4EA8176B631E204 0126CDDC33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:24:11.763923 0 SUCCESS 013300000001 7EB122DDF2B374AE7CDBF2BF473A1D9A 0126CE4C33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:24:23.617504 0 SUCCESS 013300000001 B710ABACD63738BF951175D2FDDDE926 0126CDF533FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:24:50.557704 0 SUCCESS 013300000001 1C372C66D8F7B88632648FB6C309E207 0126C88F33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:25:04.470269 0 SUCCESS 013300000001 8746F0EE21B33577748181E4B4081AC5 0126CA6633FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:25:20.594258 0 SUCCESS 013300000001 D90B687CC72FC14D9368CEE2F64569D0 0126CCF333FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:25:48.726621 0 SUCCESS 013300000001 E2E65364C81552F7DCAAECA3F16A0E30 0126CCE333FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1) metalo 2021-03-09T14:26:12.536780 0 SUCCESS 013300000001 04F68F6226AA322414B35E481A844CF1 0126CB7B33FFFFFF v2.7.1-UROB-20210112085121 (v8.7.1)
Best Regards,
guy038
-
It’s weird : Although there is a tabulation char after each word
metalo
, the lines are correctly sorted by increasing time if I perform a zero-length selection at column9
, right before the year ! -
It’s a chance, for me and you, that the
Date-Time
column is located near the beginning of lines. It allows us to find the initial lines order back, with a classical selection ;-))
-
-
@guy038 said in Identical strings in column:
Well, it’s going worse than I initially thought ! And the @alan-kilborn’s assumptions are certainly true, as well !
Intrigued by test reports with mixed outcomes, I run further tests on the same example data aiming to obtain some clarification. As before, tests were run on Windows 7 and NPP v7.9.1 and 7.9.4 RC, and threw the same outcome.
Example data with tabs, zero-length column mode selection in:
column 01 -> sorted correctly, the column mode selection remains unchanged
column 13 -> sorted correctly, but lost the column mode selection and the caret was moved to line 1, column 1
column 17 -> sorted incorrectly, lost the column mode selection and the caret was moved to line 1, column 1Now if I select all the tabs between strings 013300000001 and any checksum with a rectangular selection, backspace to delete them, get a zero-length column, type four spaces and immediately run a sort, then the command is ignored and example data remains unchanged.
Need to make a new zero-length column mode selection at columns 01, 13, or 17 in order to get example data correctly sorted. On the downside, lost the column mode selection and the caret was unexpectedly moved to line 1, column 1.
Hope this makes sense.
-
Hi, @petr-jaja, @peterjones, @astrosofista, @alan-kilborn and All,
@astrosofista, thanks for your insight, but I worked on my side and I’ve found out a coherent explanation which means that is, finally, a predictable bug !
Yes, I’m glad because I find out the algorithm which fully explains how the
column-mode
sort behaves ;-))
-
First, it only concerns the
TAB
characters, located before the position of your zero-lengthcolumn-mode
selection. Now : -
For each
TAB
character, estimate the numbern
of positions, taken by theTAB
character and, then, note the numbern - 1
-
Add up all these numbers
n- 1
( so,n1 - 1
+n2 - 1
+n3 - 1
+ … =S
)
This sum
S
is the offset between the user columnCu
of your zero-length selection AND the real columnCr
, used to perform thecolumn-mode
sort. Hence the relationCr = Cu + S
One example ( refer to the picture, below )
-
The first table, before the sort, with a zero-length column-mode selection, at column
45
-
The second table, after the sort, is not sorted, obviously, at column
45
-
Each line contains
8
tabulations before column45
-
The positions, taken by each tabulation, are, respectively,
4
,2
,3
,1
3
2
,3
and4
-
So, the numbers
n - 1
are, respectively,3
,1
,2
,0
2
1
,2
and3
-
The sum of all these “
n - 1
” numbers is14
-
So, although you think to sort at column
45
, where you did thecolumn-mode
selection, the effective sort will begin at column
45 + 14
, so at column59
of each line ! ( The column-selected column, in the picture )
Best Regards
guy038
P.S. :
-
I also verified that, after changing the number of positions for tabulations, in
normal
text, either below or above the default value4
, in thePreferences
dialog, my algorithm is still correct and always gives, in all cases, the real column of the sort ! -
Text in an
ANSI
encoded file, is sorted, using this same algorithm, too
Oh, I forgot to give the raw text :
0133 00 0000X YZ0 1 8746F0EE21B33577748181E4B4081AC5 0126CA6633FFFFFF 0133 00 0000X YZ0 1 7EB122DDF2B374AE7CDBF2BF473A1D9A 0126CE4C33FFFFFF 0133 00 0000X YZ0 1 E837148B8421B897B4EA8176B631E204 0126CDDC33FFFFFF 0133 00 0000X YZ0 1 09AD9E8A84D78DB0FBBAF2B3B22AC04F 0126CDE433FFFFFF 0133 00 0000X YZ0 1 B710ABACD63738BF951175D2FDDDE926 0126CDF533FFFFFF 0133 00 0000X YZ0 1 04F68F6226AA322414B35E481A844CF1 0126CB7B33FFFFFF 0133 00 0000X YZ0 1 D90B687CC72FC14D9368CEE2F64569D0 0126CCF333FFFFFF 0133 00 0000X YZ0 1 FB5982FE17A6B421D89F2C1C3754AB6C 0126CBD133FFFFFF 0133 00 0000X YZ0 1 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF 0133 00 0000X YZ0 1 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF 0133 00 0000X YZ0 1 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF 0133 00 0000X YZ0 1 E2E65364C81552F7DCAAECA3F16A0E30 0126CCE333FFFFFF 0133 00 0000X YZ0 1 1C372C66D8F7B88632648FB6C309E207 0126C88F33FFFFFF 0133 00 0000X YZ0 1 0316C2C8995F3578FC049D93F6087B75 0126CA6F33FFFFFF 0133 00 0000X YZ0 1 12CD01162A78F3D098AE55D134F10C0D 0126C88B33FFFFFF 0133 00 0000X YZ0 1 A7615A4D1AD8C62E8C51DB0AD65185F2 0126CDD833FFFFFF 0133 00 0000X YZ0 1 A7615A4D1AD8C62E8C51DB0AD65185F2 0126CDD833FFFFFF 0133 00 0000X YZ0 1 C8777C86BC654A5B55062F9F126E963C 0126CA6533FFFFFF 0133 00 0000X YZ0 1 C8777C86BC654A5B55062F9F126E963C 0126CA6533FFFFFF
Last thought :
If you intend to use a
column-mode
selection for a sort, starting at a specific column, the best would be to run, first, aEdit > Blank Operations > TAB to Space
command in order to delete anytabulation
character, without changing the presentation of the text ! -
-
So something smells bad here, and it isn’t just tab characters.
I looked at @guy038 's data, from the post where he said:
If I paste this data into a new tab, and convert tabs-to-spaces (to forget about tabs for now), I get something that appears like this:
If I then try to make a zero-width column selection, it looks like this:
But this isn’t right…the column caret should be to the left of the leading zero of the third column of data for the entire block, but it isn’t.
Thus if I attempt a sort, I definitely don’t obtain what I intend.
And no tabs involved.
This problem goes deeper than sorting, I think this is a Scintilla problem.
Just because the “little birdie” appears to take up two columns, he doesn’t–he’s only one character, just like all the rest of the final characters in column 1 of the data.The following is what a proper column selection should look like for this data:
-
Hello,
Great :-) It looks very nice. I have tested three files and the algorithm worked fine. I have found there only one problem. If there are more than two equal strings in the file, the sequence 3 indicates only first two of them.
Tested on v.7.9.3 - 32bit -
Thanks for this idea.
I have used at first TextFX Tools – sort lines by column and then marking lines according to your solution. Option A looks most suitable for my issue.
Tested on v.7.9.3 - 32bit -
Hello @alan-kilborn,
As you can see, in the picture below, sometines, even with
Monospaced
fonts, some characters as the∑
and other symbols like🦅
do not have the same width than standardANSI
characters, when displayed in Notepad++ !The raw text is :
01330000000🦅 A7615A4D1AD8C62E8C51DB0AD65185F2 0126CDD833FFFFFF 01330000000é 0316C2C8995F3578FC049D93F6087B75 0126CA6F33FFFFFF 01330000000∑ 12CD01162A78F3D098AE55D134F10C0D 0126C88B33FFFFFF 013300000001 FB5982FE17A6B421D89F2C1C3754AB6C 0126CBD133FFFFFF 01330000000é C8777C86BC654A5B55062F9F126E963C 0126CA6533FFFFFF 013300000001 C8777C86BC654A5B55062F9F126E963C 0126CA6533FFFFFF 01330000000∑ 09AD9E8A84D78DB0FBBAF2B3B22AC04F 0126CDE433FFFFFF 01330000000🦅 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF 01330000000é E837148B8421B897B4EA8176B631E204 0126CDDC33FFFFFF 01330000000∑ 7EB122DDF2B374AE7CDBF2BF473A1D9A 0126CE4C33FFFFFF 01330000000🦅 B710ABACD63738BF951175D2FDDDE926 0126CDF533FFFFFF 013300000001 A7615A4D1AD8C62E8C51DB0AD65185F2 0126CDD833FFFFFF 01330000000é 1C372C66D8F7B88632648FB6C309E207 0126C88F33FFFFFF 013300000001 8746F0EE21B33577748181E4B4081AC5 0126CA6633FFFFFF 01330000000∑ D90B687CC72FC14D9368CEE2F64569D0 0126CCF333FFFFFF 013300000001 E2E65364C81552F7DCAAECA3F16A0E30 0126CCE333FFFFFF 01330000000é A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF 01330000000🦅 04F68F6226AA322414B35E481A844CF1 0126CB7B33FFFFFF 013300000001 A670A18BC7CEEC1562219ABA149DA153 0126CA7833FFFFFF
So,if your going to use the
colum-mode
feature, I think that the best is to switch, first, to a classical true monospaced font, likeConsolas
orCourier New
!Best Regards
guy038
-
@guy038 said in Identical strings in column:
if … use the column-mode feature, … best is to switch … to … true monospaced font, like … Courier New !
So I’m confused.
My screenshots in my immediately previous post WERE made with the font set to Courier New.So remembering that I’ve converted all tabs to spaces, if I put my caret here:
and I press Shift+Alt+downArrow, I should get this:
because that is the only way to keep the same number of characters to the left of both carets in their respective lines.
But what I actually obtain is this:
which puts 52 characters to the left of the caret on line 1, and 53 characters to the left of the caret on line 2. And for a column mode selection this makes no sense. It is like it is doing it on a visual basis…and what good is that?!
So as an example that should really hammer this home, what if I insert a character, for example, an
a
. Here’s what happens:That’s wrong!
-
Hi, @alan-kilborn,
Don’t be bothered by my reply. Results can be different because of:
-
My old
Win XP
machine -
Old versions of some of my fonts
-
The
substitution
fonts, used by the system, to display particularUnicode
blocks -
The
fallback
font used by the system
So, just be patient, for a while, and we’ll speak about this later, when I finally get this bloody
Win 10
laptop ;-)) Otherwise, I’ll won’t be able to follow the latest N++ releases, any more !BR
guy038
-
-
Hmmm, well, Courier New seems to be about as “vanilla” as one can get, given that it is the default font in Notepad++, and every Windows computer since time began has it (I suppose).
It seems like a non-power user trying to do what I’ve shown, is going to encounter a similar problem, and complain. I guess it is debatable whether or not a non-power user is going to be doing column blocking, but maybe not out of the question.
I’m willing to keep talking about this (if there’s more to say), in the context of your old computer, because I feel this has been in existence in N++ for a long time, so such discussions should be valid.
-
Sorry. I thought briefly about that condition when I started, but I didn’t notice your 3+ example in your data when I was debugging my answer, so forgot.i am on my phone now. Maybe later today, I will get a chance to be on the computer and work on this more.
Also, maybe @guy038 solution would work better for you. ( I haven’t tried it. )
-
@Petr-Jaja said in Identical strings in column:
If there are more than two equal strings in the file, the sequence 3 indicates only first two of them.
Okay, I found a workaround. I tried a clever alternation with \K on one of them, or anchoring on \G, but that wasn’t working easily. So, as I often do for practical solutions rather than optimized solutions, I added another step.
Step 4 (as listed above) will catch 2, or 4, or 6, or any even number of replicated rows. But any odd number of rows will miss the last row. So added a step 4b:
- Find What =
(?-s)^([[:alnum:]]{32}).✗\x20{3}.*\R\K\1\x20{5}
Replace With =$1\x20✗\x20\x20\x20
This will take care of the odd rows out. (I tried on 2,3,4,5,6, and 7 repeats, and I see no reason it woudn’t work beyond that)
Someone cleverer than I am might be able to come up with the magical formula to reduce the number of steps. And that’s great if you’re writing an application that will be running the regex millions of times, where the efficiency improvement might save significant time (and thus money) over the lifetime of the regex. But for a sequence that you’re just running once, or only occasionally on a small number of rows, efficiency isn’t the most important.
- Find What =
-
I also tried @guy038 solution from his “I think that a solution, in fewer steps, should be possible !” post: it worked first try, without modification, on your example data, or on data modified to have two, three, four, five, six, and seven repeat rows (and thus there is no reason it shouldn’t on reasonable n>7). So his should work for you, too.
-
I have tested your solutions and both work fine. However, for futher work I will use probably the solution from @guy038 because it is a little bit faster.
Thank you very very much for your help.Tested - NP v.7.9.3 on Win10, Win7