Применить цвет лица на основе номера столбца
-
11-12-2019 - |
Вопрос
Есть так называемые строгие форматы, такие как pdb - где значениесимвола определяется номером Colomn символа.Например, Здесь - это спецификация вышеупомянутого формата PDB.
.Есть ли способ, которым я могу применить цвет лица, основываясь на диапазоне колонны?
Обычно можно добавить регентэксп, чтобы быть выделенным, например, для текущего сеанса следующим образом:
(font-lock-add-keywords nil '(("\\[\\(.+?\\)\\]" . font-lock-keyword-face)))
.
Так есть ли способ указать, что лицо на столбцах, скажем, 7-11 - должно быть, скажем - красный?
Так что ответ:
(font-lock-add-keywords nil '(("^.\\{2\\}\\(.\\{2\\}\\)" 1 font-lock-warning-face)))
. Решение
Определите Regexp, которое выберут соответствующий столбец.
Например, чтобы выбрать 3-й столбец (при условии, что столбцы содержит только букву для ясности примера), вы можете сделать что-то вроде "\(?:[a-z]+ \)\{2\}\([a-z]+\)"
, а затем совпадать на первой группе.
Конечно, вы можете создать такую строку, используя format
и передачу его аргументами для большей гибкости.
(font-lock-add-keywords nil '(("\\(?:[a-z]+ \\)\\{2\\}\\([a-z]+\\)" 1 font-lock-warning-face)))
как другое направление, в режиме WhiteSpace был найден следующий код, который подчеркивает символы по определенному номеру:
;; Show "long" lines
(list
(let ((line-column (or whitespace-line-column fill-column)))
(format
"^\\([^\t\n]\\{%s\\}\\|[^\t\n]\\{0,%s\\}\t\\)\\{%d\\}%s\\(.+\\)$"
whitespace-tab-width
(1- whitespace-tab-width)
(/ line-column whitespace-tab-width)
(let ((rem (% line-column whitespace-tab-width)))
(if (zerop rem)
""
(format ".\\{%d\\}" rem)))))
(if (memq 'lines whitespace-active-style)
0 ; whole line
2) ; line tail
whitespace-line t)
. Другие советы
Следующее заявило окраску изначально к тексту с 7 по 11 столбец:
(defun bk-pdb-color-ATOM-initially()
(interactive)
(save-excursion
(goto-char (point-min))
(while (search-forward-regexp "^ATOM \\(.\\{5\\}\\).\\(.\\{4\\}\\).\\(.\\{3\\}\\).\\(.\\{5\\}\\).\\{4\\}\\(.\\{24\\}\\)" nil t)
(progn
(overlay-put
(make-overlay (match-beginning 1) (match-end 1))
'face '(:foreground "blue"))
(overlay-put
(make-overlay (match-beginning 2) (match-end 2))
'face '(:foreground "red"))
(overlay-put
(make-overlay (match-beginning 3) (match-end 3))
'face '(:foreground "purple1"))
(overlay-put
(make-overlay (match-beginning 4) (match-end 4))
'face '(:foreground "orange"))
(overlay-put
(make-overlay (match-beginning 5) (match-end 5))
'face '(:foreground "green"))
t nil)
)))
.