Community
    • Login

    Replacing variable length file paths in a GEDCOM file

    Scheduled Pinned Locked Moved Help wanted · · · – – – · · ·
    44 Posts 5 Posters 3.1k Views
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • Web MasterW
      Web Master @PeterJones
      last edited by

      @peterjones As webmaster for a society where our dempgraphic is 55 - 95, having to deal with questions like “Why doesn’t it work?” and “What do you mean by right-click?”, I frequently have to tell people to ‘follow the friggin’ instructions’ (expletives deleted.)

      I’m a complete numpty about regex though, so I’m sure I will tax your paitence in other ways!

      1 Reply Last reply Reply Quote 0
      • Alan KilbornA
        Alan Kilborn @Web Master
        last edited by

        @web-master said in Replacing variable length file paths in a GEDCOM file:

        The file could contain thousands of lines that all start "FILE 1 ", does that change things?

        Nope, that’s what was anticipated from your problem description.

        I’m sure with your attitude you could become adept at regex; there are resources on the FAQ page that you should check out.

        1 Reply Last reply Reply Quote 2
        • Web MasterW
          Web Master @Alan Kilborn
          last edited by

          @alan-kilborn said in Replacing variable length file paths in a GEDCOM file:

          @web-master said in Replacing variable length file paths in a GEDCOM file:

          Something like this:

          Find: (?-s)^(1 FILE ).+/
          Replace: ${1}/Smith_1234/
          Search mode: Regular expression

          but some of the files have 1million lines!!!

          With that much data, before any important transformation operation, please back up your data!

          Wow! Got it in one! It worked.

          Mind you, the file I chose at random to test it on has a variation on the theme because instead of each line starting "1 FILE " they started "2 FILE ". But tweaking the expression fixed that. What would the syntax be for any line starting 0 - 9 then FILE, please?

          PeterJonesP 1 Reply Last reply Reply Quote 0
          • PeterJonesP
            PeterJones @Web Master
            last edited by PeterJones

            @web-master said in Replacing variable length file paths in a GEDCOM file:

            What would the syntax be for any line starting 0 - 9 then FILE, please?

            \d means match a single digit (0-9); \d+ means match one or more digits (0-99999…)

            Web MasterW 1 Reply Last reply Reply Quote 1
            • Web MasterW
              Web Master @PeterJones
              last edited by

              @peterjones said in Replacing variable length file paths in a GEDCOM file:

              @web-master said in Replacing variable length file paths in a GEDCOM file:

              What would the syntax be for any line starting 0 - 9 then FILE, please?

              \d means match a single digit (0-9); \d+ means match one or more digits (0-99999…)

              OK so if the Find what becomes…

              (?-s)^\d( FILE ).+/

              … the replace with gets SNAFU’d and loses the inital number

              FILE /Smith_1234/Robert Frederic & Audrey Lilian - 3.jpg

              instead of

              2 FILE /Smith_1234/Robert Frederic & Audrey Lilian - 3.jpg

              How do I pass the initial number from the find to the replace please?

              PeterJonesP 1 Reply Last reply Reply Quote 0
              • PeterJonesP
                PeterJones @Web Master
                last edited by PeterJones

                @web-master ,

                Why did you take it out of the parentheses? You had (?-s)^(1 FILE ).+/, and I suggested that you use \d instead of 1, which would have been (?-s)^(\d FILE ).+/ … if the \d is in the parentheses, it will be included in the replacement using the $1 that’s already there.

                Web MasterW 1 Reply Last reply Reply Quote 2
                • Web MasterW
                  Web Master @PeterJones
                  last edited by

                  @peterjones I figured that 1 FILE inside the paranetheses was a literal.

                  PeterJonesP 1 Reply Last reply Reply Quote 0
                  • PeterJonesP
                    PeterJones @Web Master
                    last edited by PeterJones

                    @web-master ,

                    I figured that 1 FILE inside the paranetheses was a literal.

                    The parentheses doesn’t make it literal. The parentheses makes it a group, so that it will capture the matched text inside the parentheses as a group, which you can then reference during the replacement to get back pieces of what was in your match. By taking the \d outside the parentheses, the digit wasn’t kept as part of the group, and thus wasn’t available to be inserted into the replacement.

                    • capture groups (see Numbered Capture Group in that section)
                    • replacement expressions (see $ℕ in that section)
                    Web MasterW 1 Reply Last reply Reply Quote 1
                    • Web MasterW
                      Web Master @PeterJones
                      last edited by

                      @peterjones Got it! Thank you

                      This works beautifully. Is there a way to put this into a macro so that at runtime the user is prompted for the replacement string? That would be the cherry on top of the icing/frosting on top of the cake.

                      No biggie if it’s too big an ask. I’m sure I can coach the user to do it properly

                      Paul

                      PeterJonesP Alan KilbornA 2 Replies Last reply Reply Quote 0
                      • PeterJonesP
                        PeterJones @Web Master
                        last edited by

                        @web-master ,

                        The macro language used by Notepad++ has no concept of “prompt”, so the simple answer is “no”.

                        “Or something”, OTOH: there is a PythonScript plugin, which allows you to write a script that is run inside of Notepad++ which can automate the Notepad++ GUI and editor contents, which could run that search/replace; but you’d have to install the plugin, and learn how to write such a script. It really depends on how much effort you want to go to now, to make it easier for your users to do this in the future. I think Alan’s posted at least one script in the past that pops up a user input box and asks for text, which then gets populated into a regex that is automatically run on the current file… searching the forum for posts by @Alan-Kilborn that contain prompt might get you there eventually (though you’ll probably have to wade through quite a few false hits as well… prompt isn’t that uncommon a word).

                        Web MasterW 1 Reply Last reply Reply Quote 1
                        • Web MasterW
                          Web Master @PeterJones
                          last edited by

                          @peterjones Thanks. I’ll try coaching the user first. :)

                          I am so impresssed with the speed and quality of response to my post. Thank you so much Alan and Peter

                          Neil SchipperN 1 Reply Last reply Reply Quote 2
                          • Neil SchipperN
                            Neil Schipper @Web Master
                            last edited by Neil Schipper

                            @web-master Hi. Here’s a variation on Alan’s solution which has the feature that users enter the replacement text as is (so they won’t have to be so careful about entering text into a field containing cryptic regex codes) : (?<=^\d FILE /).*(?=/)

                            (Edit: slightly simplified)

                            Web MasterW 1 Reply Last reply Reply Quote 2
                            • Web MasterW
                              Web Master @Neil Schipper
                              last edited by

                              @neil-schipper said in Replacing variable length file paths in a GEDCOM file:

                              (?<=^\d FILE /).*(?=/)

                              Forgive me Neil, but I’m not clear how to use this modified example?

                              Neil SchipperN 1 Reply Last reply Reply Quote 0
                              • Neil SchipperN
                                Neil Schipper @Web Master
                                last edited by

                                @web-master I could have been more clear.

                                The idea is that you perform a Regex search in the same way as the earlier recipe, except the Find expression is the one I offered, and, the Replace expression is simply and completely the text you want to substitute in.

                                Thus, instead of your people having to carefully modify the Replace expression from ${1}/Smith_1234/ to ${1}/Jones_4567/ as they proceed from one task to the next, they can more comfortably change Smith_1234 to Jones_4567 – no funny confusing text in the Replace text box.

                                Also, if you want the solution to be robust against users inadvertently checking that option box to the right of Reg Exp, prefix the Find expression with (?-s) as per Alan’s earlier expression.

                                Also, if you want to make it impossible to match a completely empty path (nothing between two slashes: //), in my Find expression, we’d replace * with +, hence: (?-s)(?<=^\d FILE /).+(?=/)

                                Web MasterW Alan KilbornA 2 Replies Last reply Reply Quote 1
                                • Web MasterW
                                  Web Master @Neil Schipper
                                  last edited by

                                  @neil-schipper Hi Neil. OK, that’s what I thought you meant, but when I do that, Find and Replace does nothing

                                  Neil SchipperN 1 Reply Last reply Reply Quote 0
                                  • Alan KilbornA
                                    Alan Kilborn @Neil Schipper
                                    last edited by

                                    @neil-schipper said in Replacing variable length file paths in a GEDCOM file:

                                    Also, if you want to make it impossible to match a completely empty path (nothing between two slashes: //), in my Find expression, we’d replace * with +

                                    I’m surprised you changed (my) original usage of .+ to .* in your version, then backed it out with “we’d replace * with +”. :-)

                                    Neil SchipperN 1 Reply Last reply Reply Quote 0
                                    • Neil SchipperN
                                      Neil Schipper @Web Master
                                      last edited by

                                      @web-master

                                      Just to be clear:
                                      Find: (?-s)(?<=^\d FILE /).+(?=/)
                                      Replace: Smith_1234
                                      Mode=regex; checkbox to the right doesn’t matter anymore

                                      Then, Find Next to observe expected matching, Replace to perform the substitution on the currently selected match, Replace All to perform the substitution on entire file.

                                      I have tested this. Are you sure you aren’t acting on a file that has already had the substitutions done?

                                      Web MasterW 1 Reply Last reply Reply Quote 0
                                      • Neil SchipperN
                                        Neil Schipper @Alan Kilborn
                                        last edited by

                                        @alan-kilborn said:

                                        you changed (my) original usage of .+ to .*

                                        That’s not how it actually went. I devised my solution independently from reading the OP (deciding early that it should have a look-behind and a look-ahead). Then I saw you had a solution that was satisfactory, and I saw no reason to pipe in.

                                        Much later I noticed in the follow-up convo that @web-master was trying to reduce complexity for his non-technical volunteers, and realized my solution was favorable to that. And it was after that that I realized our solutions also differed in the modifier, and that the asterisk was maybe a bit too loose (although, dollars to doughnuts, they perform equally).

                                        1 Reply Last reply Reply Quote 1
                                        • Alan KilbornA
                                          Alan Kilborn @Web Master
                                          last edited by Alan Kilborn

                                          @web-master said in Replacing variable length file paths in a GEDCOM file:

                                          Is there a way to put this into a macro so that at runtime the user is prompted for the replacement string?

                                          As @PeterJones mentioned, not possible with a macro.

                                          But as a PythonScript it is rather simple:

                                          replacement_text = notepad.prompt('Replacement text:', '', '')
                                          if replacement_text:
                                              find_regex = r'(?-s)(?<=^\d FILE /).+(?=/)'
                                              editor.rereplace(find_regex, replacement_text)
                                          

                                          You’d run the script and then get prompted with:

                                          a7afa474-b454-42b6-82e0-47d305e365b2-image.png

                                          After pressing OK the replacements would be made.

                                          1 Reply Last reply Reply Quote 2
                                          • Web MasterW
                                            Web Master @Neil Schipper
                                            last edited by

                                            @neil-schipper Yes, I copied and pasted the expression direct from here and the file had def not been processed already.

                                            I don’t know what the protocol is here. May I PM you the file so you can try it?

                                            Alan KilbornA Neil SchipperN 2 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post
                                            The Community of users of the Notepad++ text editor.
                                            Powered by NodeBB | Contributors