Emacs - как отформатировать блок текста в форме электронной таблицы? - PullRequest
4 голосов
/ 18 ноября 2010

Есть ли в emacs команда / режим для форматирования блока текста следующим образом:

; before
; p1 p2 p3 p4 p5 p6 p7 p8 p9 p10
i 107 0 1 10000 440 1
i 107 1.5 1 20000 220 2
i 107 3 2 10000 110 2
i 107 3.5 2.5 10000 138.6 2
i 107 4 2 5000 329.6 2
i 107 4.5 1.5 6000 440 2
i 108 7 1 10000 440 1 2 3 1
i 108 8.5 1 10000 220 1 0.5 8 1
i 108 10 3 10000 110 1 1 13 1
i 108 10.5 2.5 10000 130.8 1 2.001 8 1

в это?

; after
; p1  p2   p3  p4    p5    p6 p7    p8 p9 p10
i 107 0    1   10000 440   1
i 107 1.5  1   20000 220   2
i 107 3    2   10000 110   2
i 107 3.5  2.5 10000 138.6 2
i 107 4    2   5000  329.6 2
i 107 4.5  1.5 6000  440   2
i 108 7    1   10000 440   1  2     3  1
i 108 8.5  1   10000 220   1  0.5   8  1
i 108 10   3   10000 110   1  1     13 1
i 108 10.5 2.5 10000 130.8 1  2.001 8  1

Ответы [ 3 ]

4 голосов
/ 18 ноября 2010

попробуй M-x table-capture

1 голос
/ 21 ноября 2010

Вы можете использовать поддержку таблицы в режиме emacs org для создания таблицы из региона, а затем удалить разделители столбцов после ее завершения.

Выделите нужную область, затем выполните

M-x org-table-create-or-convert-from-region

Ваши результаты будут выглядеть так:

; before
| ; |  p1 |   p2 |  p3 |    p4 |    p5 | p6 |    p7 | p8 | p9 | p10 |
| i | 107 |    0 |   1 | 10000 |   440 |  1 |       |    |    |     |
| i | 107 |  1.5 |   1 | 20000 |   220 |  2 |       |    |    |     |
| i | 107 |    3 |   2 | 10000 |   110 |  2 |       |    |    |     |
| i | 107 |  3.5 | 2.5 | 10000 | 138.6 |  2 |       |    |    |     |
| i | 107 |    4 |   2 |  5000 | 329.6 |  2 |       |    |    |     |
| i | 107 |  4.5 | 1.5 |  6000 |   440 |  2 |       |    |    |     |
| i | 108 |    7 |   1 | 10000 |   440 |  1 |     2 |  3 |  1 |     |
| i | 108 |  8.5 |   1 | 10000 |   220 |  1 |   0.5 |  8 |  1 |     |
| i | 108 |   10 |   3 | 10000 |   110 |  1 |     1 | 13 |  1 |     |
| i | 108 | 10.5 | 2.5 | 10000 | 130.8 |  1 | 2.001 |  8 |  1 |     |

На данный момент вы можете искать и заменять | символ, разделяющий столбцы, чтобы получить

; before
;  p1   p2  p3    p4    p5 p6    p7 p8 p9 p10
i 107    0   1 10000   440  1                
i 107  1.5   1 20000   220  2                
i 107    3   2 10000   110  2                
i 107  3.5 2.5 10000 138.6  2                
i 107    4   2  5000 329.6  2                
i 107  4.5 1.5  6000   440  2                
i 108    7   1 10000   440  1     2  3  1    
i 108  8.5   1 10000   220  1   0.5  8  1    
i 108   10   3 10000   110  1     1 13  1    
i 108 10.5 2.5 10000 130.8  1 2.001  8  1 
1 голос
/ 18 ноября 2010

Я не уверен, что это то же самое, но в режиме org есть отличная поддержка таблиц

активируйте режим org и попробуйте любой из этих

  • запись макроса клавиатуры для добавления '|' между полями (если ваши таблицы не редки или нет пустой ячейки)

  • используйте regexp-replace для преобразования пробела в '|'

затем играйте с ним как в Excel

PS: если вам нужно больше, просто спросите

...