Right-align text in Emacs

后端 未结 1 1790
北荒
北荒 2021-01-02 08:03

Sometimes, I have a text file like this in Emacs:

some text     123     17
other text    1       0
still more    12      8
last one      1234    123
<         


        
1条回答
  •  挽巷
    挽巷 (楼主)
    2021-01-02 09:01

    align-regexp can do this. Mark the region, and then use:

    C-uM-x align-regexp RET \(\s-+[0-9]*\)[0-9] RET -1 RET 4 RET y

    That should be the simplest approach.

    (Edit: In fact, you don't even need to separate out that final digit; \(\s-+[0-9]+\) works just as well for the regexp.)

    See the interactive prompts and C-hf align-regexp RET and the align-rules-list variable for what that is actually doing.

    The noteworthy part is that by specifying a negative number for the group, align-regexp sets the justify attribute:

    `justify'   
    It is possible with `regexp' and `group' to identify a
    character group that contains more than just whitespace
    characters.  By default, any non-whitespace characters in
    that group will also be deleted while aligning the
    alignment character.  However, if the `justify' attribute
    is set to a non-nil value, only the initial whitespace
    characters within that group will be deleted.  This has
    the effect of right-justifying the characters that remain,
    and can be used for outdenting or just plain old right-
    justification.
    

    Alternatively the various table-editing options can also deal with this (e.g. org, ses, table-capture/release), or you could do it with an elisp replacement pattern.

    e.g. The following should do more or less what you're looking for, provided that the file is already using spaces for alignment (you can use untabify to remove the tabs if not), and that all lines are the same length (i.e. trailing spaces are needed on some lines if the final column is of varying length).

    C-M-% \([0-9]+\)\([[:space:]]+\) RET \,(format (concat "%" (number-to-string (1- (length \&))) "d ") (string-to-number \1)) RET

    0 讨论(0)
提交回复
热议问题