Tumgik
#ignorecase
vim-official · 1 month
Text
vimrc, git clone plugins into ~/.vim/bundle
" http://vimdoc.sourceforge.net/htmldoc/starting.html#vimrc execute pathogen#infect()
set nocompatible " use vim defaults set scrolloff=3 " keep 3 lines when scrolling set ai " set auto-indenting on for programming
set showcmd " display incomplete commands set nobackup " do not keep a backup file set number " show line numbers set ruler " show the current row and column
set hlsearch " highlight searches set incsearch " do incremental searching set showmatch " jump to matches when entering regexp set ignorecase " ignore case when searching set smartcase " no ignorecase if Uppercase char present set relativenumber
set visualbell t_vb= " turn off error beep/flash "set novisualbell " turn off visual bell
set backspace=indent,eol,start " make that backspace key work the way it should "set runtimepath=$VIMRUNTIME " turn off user scripts, https://github.com/igrigorik/vimgolf/issues/129
set mouse=a set spell let g:lexical#spelllang = ['en_us'] let g:lexical#thesaurus = ['~/.vim/thesaurus/mthesaur.txt',] syntax on " turn syntax highlighting on by default filetype on " detect type of file filetype plugin indent on " load indent file for specific file type colorscheme dracula
set t_RV= " http://bugs.debian.org/608242, http://groups.google.com/group/vim_dev/browse_thread/thread/9770ea844cec3282 let g:ycm_global_ycm_extra_conf = "~/.vim/.ycm_extra_conf.py" set encoding=utf-8 let g:airline_theme='dracula' " let g:airline_theme='violet' let g:airline#extenstions#tabline#enabled = 1 let g:tex_flavor = 'latex' if !exists('g:ycm_semantic_triggers') let g:ycm_semantic_triggers = {} endif au VimEnter * let g:ycm_semantic_triggers.tex=g:vimtex#re#youcompleteme
nnoremap ^[ ^[ let g:UltiSnipsExpandTrigger = '' " use Tab to expand snippets let g:UltiSnipsJumpForwardTrigger = '' " use Tab to move forward through tabstops let g:UltiSnipsJumpBackwardTrigger = '' " use Shift-Tab to move backward through tabstops let g:UltiSnipsSnippetDirectories=[$HOME.'/.vim/UltiSnips'] " using Vim augroup pencil autocmd! autocmd FileType markdown,mkd call pencil#init() \ | call litecorrect#init() \ | call lexical#init() autocmd FileType tex call pencil#init() \ | call litecorrect#init() \ | call lexical#init() autocmd FileType text call pencil#init() \ | call litecorrect#init() \ | call lexical#init() augroup END au FileType markdown,text,tex DittoOn " Turn on Ditto's autocmds nmap di ToggleDitto " Turn Ditto on and off nmap =d DittoNext " Jump to the next word nmap -d DittoPrev " Jump to the previous word nmap +d DittoGood " Ignore the word under the cursor nmap _d DittoBad " Stop ignoring the word under the cursor nmap ]d DittoMore " Show the next matches nmap [d DittoLess " Show the previous matches
let g:pencil#wrapModeDefault = 'soft' " default is 'hard' setlocal fo+=aw nnoremap x ZZ
0 notes
Text
javascript cheat sheet download hack 41NL&
💾 ►►► DOWNLOAD FILE 🔥🔥🔥🔥🔥 A complete quick reference Free to download as PDF! Here you can go with the quick guide or JS cheat sheet which will help you to know more about shortcuts and. Alongside HTML and CSS, it is a core technology that makes the web. 7 Resource Online Official Website. Download JavaScript Cheat Sheet [. Basic Objects Array Properties constructor length prototype. Boolean Properties constructor prototype. Boolean Methods toString valueOf. Math Methods abs x acos x asin x atan x atan2 y,x ceil x cos x exp x floor x log x max x,y,z, String Properties constructor length prototype. Global Properties Infinity NaN undefined. Date Object Date Properties constructor prototype. History Properties length. History Methods back forward go. Location Properties hash host hostname href pathname port protocol search. Location Methods assign reload replace. Keyboard Events keydown keypress keyup. Frame Events abort error load resize scroll unload. Form Events blur change focus reset select onsubmit. EventListener Object handleEvent. RegExp Modifiers i Perform case-insensitive matching g Perform a global match find all matches rather than stopping after the first match m Perform multiline matching. RegExp Properties global ignoreCase lastIndex multiline source. RegExp Methods exec test. Nodelist Methods item. NamedNodeMap Properties length. Element Properties schemaTypeInfo tagName.
1 note · View note
Text
javascript cheat sheet download work NN3&
💾 ►►► DOWNLOAD FILE 🔥🔥🔥🔥🔥 A complete quick reference Free to download as PDF! Here you can go with the quick guide or JS cheat sheet which will help you to know more about shortcuts and. Alongside HTML and CSS, it is a core technology that makes the web. 7 Resource Online Official Website. Download JavaScript Cheat Sheet [. Basic Objects Array Properties constructor length prototype. Boolean Properties constructor prototype. Boolean Methods toString valueOf. Math Methods abs x acos x asin x atan x atan2 y,x ceil x cos x exp x floor x log x max x,y,z, String Properties constructor length prototype. Global Properties Infinity NaN undefined. Date Object Date Properties constructor prototype. History Properties length. History Methods back forward go. Location Properties hash host hostname href pathname port protocol search. Location Methods assign reload replace. Keyboard Events keydown keypress keyup. Frame Events abort error load resize scroll unload. Form Events blur change focus reset select onsubmit. EventListener Object handleEvent. RegExp Modifiers i Perform case-insensitive matching g Perform a global match find all matches rather than stopping after the first match m Perform multiline matching. RegExp Properties global ignoreCase lastIndex multiline source. RegExp Methods exec test. Nodelist Methods item. NamedNodeMap Properties length. Element Properties schemaTypeInfo tagName.
1 note · View note
Text
javascript cheat sheet download PC C5FD+
💾 ►►► DOWNLOAD FILE 🔥🔥🔥🔥🔥 A complete quick reference Free to download as PDF! Here you can go with the quick guide or JS cheat sheet which will help you to know more about shortcuts and. Alongside HTML and CSS, it is a core technology that makes the web. 7 Resource Online Official Website. Download JavaScript Cheat Sheet [. Basic Objects Array Properties constructor length prototype. Boolean Properties constructor prototype. Boolean Methods toString valueOf. Math Methods abs x acos x asin x atan x atan2 y,x ceil x cos x exp x floor x log x max x,y,z, String Properties constructor length prototype. Global Properties Infinity NaN undefined. Date Object Date Properties constructor prototype. History Properties length. History Methods back forward go. Location Properties hash host hostname href pathname port protocol search. Location Methods assign reload replace. Keyboard Events keydown keypress keyup. Frame Events abort error load resize scroll unload. Form Events blur change focus reset select onsubmit. EventListener Object handleEvent. RegExp Modifiers i Perform case-insensitive matching g Perform a global match find all matches rather than stopping after the first match m Perform multiline matching. RegExp Properties global ignoreCase lastIndex multiline source. RegExp Methods exec test. Nodelist Methods item. NamedNodeMap Properties length. Element Properties schemaTypeInfo tagName.
1 note · View note
codehunter · 3 years
Text
Case insensitive regular expression without re.compile?
In Python, I can compile a regular expression to be case-insensitive using re.compile:
>>> s = 'TeSt'>>> casesensitive = re.compile('test')>>> ignorecase = re.compile('test', re.IGNORECASE)>>> >>> print casesensitive.match(s)None>>> print ignorecase.match(s)<_sre.SRE_Match object at 0x02F0B608>
Is there a way to do the same, but without using re.compile. I can't find anything like Perl's i suffix (e.g. m/test/i) in the documentation.
https://codehunter.cc/a/python/case-insensitive-regular-expression-without-re-compile
0 notes
jimsjoo · 3 years
Text
간단하게 정규표현식 사용하기
VBA가 문자열 다루기는 편리한 편이지만 그래도 정규표현식같은 것을 직접 지원하지는 않는다. 가장 간단한 방법은 사촌동생격인 VBScript의 RegExp개체를 이용하는 것이다. Sub DemoRegexp() Dim Str As String Dim results(1) As String Dim RE As Object, REMatches As Object Set RE = CreateObject("vbscript.regexp") With RE .MultiLine = False .Global = True .IgnoreCase = True .Pattern = "^(.*?)(\[(.*)\])?$" End With Str = "Test[Bar]" Set REMatches =…
View On WordPress
0 notes
netsurfingzone · 3 years
Link
Tumblr media
0 notes
udemyfc · 4 years
Text
Hands-on Python3 Regular Expressions for Absolute Beginners
Hands-on Python3 Regular Expressions for Absolute Beginners
Requirements Eager to learnInternet connectivityNo prior knowledge in regular expression Description This course provides you clear cut concept in regular expression,external modules and data scrapping using python and you will learn different types of pattern matching,use of dollar,caret,plus,question mark symbols and also VERBOSE,IGNORECASE functions also some of third party module like…
Tumblr media
View On WordPress
0 notes
raj89100 · 5 years
Text
Solr Indexing/Searching Hindi documents
Solr support many languages where user can indexing/searching their documents.In this article we will discuss how indexing/searching done in one of the most popular language in india which is also nation’s national language.
Solr provide three filters to handle hindi language very well.These are as below:
IndicNormalizationFilterFactory
HindiNormalizationFilterFactory
HindiStemFilterFactory
Let’s look now how we can configure above filterfactories and use them.
Table of Contents [hide]
Step 1: Create FieldTyeStep 2: Field Configuration
Step 3: Add documents
Step 4: Search documents
Was this post helpful?
Step 1: Create FieldTye
Create custom fieldType and add above FilterFactory as below.
<fieldType name="text_hindi" class="solr.TextField" positionIncrementGap="100"> <analyzer type="index"> <tokenizer class="solr.WhitespaceTokenizerFactory"/> <filter class="solr.SynonymFilterFactory" synonyms="hindi/synonyms.txt" ignoreCase="true" expand="true"/> <!-- Case insensitive stop word removal. add enablePositionIncrements=true in both the index and query analyzers to leave a 'gap' for more accurate phrase queries. --> <filter class="solr.StopFilterFactory" words="hindi/stopwords.txt" ignoreCase="true" enablePositionIncrements="true"/> <filter class="solr.LowerCaseFilterFactory"/> <filter class="solr.HindiStemFilterFactory" protected="hindi/protwords.txt"/> <filter class="solr.RemoveDuplicatesTokenFilterFactory"/> <filter class="solr.IndicNormalizationFilterFactory"/> <filter class="solr.HindiNormalizationFilterFactory"/> </analyzer> <analyzer type="query"> <tokenizer class="solr.WhitespaceTokenizerFactory"/> <filter class="solr.StopFilterFactory" words="hindi/stopwords.txt" ignoreCase="true" enablePositionIncrements="true"/> <filter class="solr.LowerCaseFilterFactory"/> <filter class="solr.HindiStemFilterFactory" protected="hindi/protwords.txt"/> <filter class="solr.RemoveDuplicatesTokenFilterFactory"/> <filter class="solr.IndicNormalizationFilterFactory"/> <filter class="solr.HindiNormalizationFilterFactory"/> </analyzer> </fieldType>
Step 2: Field Configuration
Now use above created field type in field defination.
<field name="FULL_TEXT" type="text_hindi" indexed="true" stored="true"/>
Step 3: Add documents
Add documents which has hindi content like “जावा डेवलपर ज़ोन बहुत अच्छे ब्लॉग लिखते हैं”. here we are using solr upload document command  solr gui dashboard.
Tumblr media
Step 4: Search documents
That’s it.To test whether particular document is indexed or not.Fire query like FULL_TEXT:”जावा डेवलपर”.Solr will return one document as below.
Tumblr media
0 notes
klvst3r · 5 years
Text
Permiso denegado - Bitbucket (clave pública). fatal: no se pudo leer desde el repositorio remoto.
Tumblr media
Tengo una cuenta individual de bitbucket y recientemente creé un nuevo repositorio de bitbucket en mi cuenta individual e inserté el código de un repositorio local en él. Luego transfirí ese repositorio de mi cuenta individual a la cuenta de mi equipo, y acepté la transferencia en nombre de mi equipo.Después de hacer algunos cambios en mi base de código local, intenté enviar esos cambios al origen con un git push y recibí el siguiente mensaje de error:
nw-client (master)]$ git push fatal: https://[myname]@bitbucket.org/[myname]/nw-html-client.git/info/refs?service=git-receive-pack not found: did you run git update-server-info on the server?
En ese momento me di cuenta de que necesitaba actualizar la URL de mi origen, así que escribí el siguiente comando git en el terminal:
git remote set-url origin [email protected]:[myteamname]/nw-html-client.git
Pero,
 git ls-remote
devoluciones
[nw-client (master)]$ git ls-remote Permission denied (publickey). fatal: Could not read from remote repository. Please make sure you have the correct access rights and the repository exists.
Mi archivo git.config se ve así:
[core] repositoryformatversion = 0 filemode = true bare = false logallrefupdates = true ignorecase = true precomposeunicode = false [remote "origin"] url = git@bitbucket.[myteamname]/nw-html-client.git fetch = +refs/heads/*:refs/remotes/origin/* [branch "master"] remote = origin merge = refs/heads/master
Parece que tenía mi repositorio bajo el protocolo HTTPS y una vez que se configuró el origen de la URL, el repositorio se conectó bajo el protocolo SSH.
Sería posible generar un par de claves, agregar la clave pública a al repositorio de Bitbucket y la clave privada al ssh.
Tambien esto puede funcionar y se puede solucionar el problema inicial se resolvió, pero ahora no puedo realizar una inserción de mi confirmación debido a este error:
repository access denied. access via a deployment key is read-only. fatal: Could not read from remote repository.
Lo primero que me viene a la mente se relaciona con la clave SSH utilizada que tiene permisos de 'Lectura' y no permiso de 'Lectura / Escritura'.
Para obtener más información, consulte las claves de acceso SSH para la documentación de uso del sistema .
La documentación mencionada en las referencias ( claves de acceso SSH para uso del sistema ) se relaciona con Bitbucket Server.Quizás, vaya a su cuenta de usuario en Bitbucket Cloud y agregue la clave SSH desde allí (icono Cog >> Configuración de Bitbucket >> Seguridad >> Claves SSH)
No puedo decir de manera concluyente si funcionó: cuando intenté ejecutar el comando push recibí un error sobre la URL no encontrada. Cambié el tipo de repositorio de SSH a HTTPS en Sourcetree, que cambió la URL. Cuando intenté presionar nuevamente, se me solicitó una ventana para ingresar las credenciales de bitbucket (debido al método HTTPS) y finalmente pude realizar la confirmación, pero no puedo decir si las claves SSH configuradas en el lado del servidor cualquier cosa que hacer, probablemente no.En cualquier caso, la ventana Agregar claves SSH tampoco tenía la opción Leer / Escribir.
Entonces: ¿la clave SSH establecida en la sección del servidor sería global para cualquier cosa en la cuenta de bitbucket (en lugar de específica para el repositorio)?
La respuesta lo resolví cuando cambié la URL remota a HTTPS con este comando:
git remote set-url origin <bitbucket_URL>
Después de eso, podría enviar el contenido al repositorio con este comando: 
git push -u origin --all
Esto me solicitara nuevamente las credenciales de mi cuenta en Bitbucket, les registre y listo pude ver mi información en mi repositorio remoto.
Referencias:
https://translate.googleusercontent.com/translate_c?depth=1&hl=es&rurl=translate.google.com.mx&sl=en&sp=nmt4&tl=es&u=https://confluence.atlassian.com/bitbucketserver/ssh-access-keys-for-system-use-776639781.html&xid=17259,15700022,15700186,15700190,15700256,15700259,15700262,15700265&usg=ALkJrhg1wtRv3gBwlUocmOz2lniM2XxFCw
0 notes
yyq123 · 5 years
Text
VIM学习笔记 自动补全选项(Auto-Completion-Option)
在插入模式下,利用自动补全(Insertion-Completion)功能,vim能够根据正在输入的字符,查找匹配的关键字并显示在弹出菜单(popup menu)中。通过选择匹配项,可以补全输入的部分关键字甚至整行文本。
关键字补全选项
使用Ctrl-N或Ctrl-P快捷键,将按照'complete'选项指定的范围来搜索匹配的关键字。其默认值为:
:set complete=.,w,b,u,t,i
也就是说,默认将在以下来源中查找关键字:
在当前缓冲区中进行查找;
在其他窗口中进行查找;
在其他已载入的缓冲区中进行查找;
在没有载入缓冲区的文件中进行查找;
在当前的标签(tags)列表进行查找;
在由当前文件(如#include)包含进来的头文件中进行查找。
假设文件中包含以下句子:
I have beautiful flowers in my flower garden
我们另起一行并输入“f”字母,然后点击Ctrl-X Ctrl-N快捷键,将会在当前文件内查找已经存在的单词:
而使用Ctrl-N快捷键,将会根据'complete'选项指定的范围进行查找。比如在其它缓冲区内找到了更多以f开头的单词:
通过以下命令设置'complete'选项,可以定义自动补全的查找范围:
:set complete=key,key,key
命令中可能出现的key值如下:
.当前缓冲区 b缓冲区列表中的其它已载入的缓冲区 d当前文件以及由'include'选项指定的包含进来的文件 查找由'define'选项定义的宏(definition/macro) i当前文件以及由'include'选项指定的包含进来的文件 k由'dictionary'选项指定的文件 kspell当前激活的拼写检查 k{dict}名为{dict}的文件 s由'thesaurus'选项指定的文件 t标签(tags)文件 ] u缓冲区列表中的没有载入的缓冲区 w在其他窗口中载入的文件
使用以下命令,可以将字典文件添加到搜索列表中:
:set complete+=k
使用以下命令,可以将包含的文件从搜索列表中移除:
:set complete-=i
使用:h 'complete'命令,可以查看'complete'选项的帮助信息。
忽略大小写
如果我们使用以下命令,设置了在查找过程中忽略大小写,那么在自动完成时,反而会造成区分大小写:
:set ignorecase
使用以下命令,则可以设置在自动完成时忽略大小写:
:set infercase
Ver: 2.0 | YYQ<上一篇 | 目录 | 下一篇>
from Blogger https://ift.tt/2UJZDgX via IFTTT
0 notes
vimtry · 5 years
Text
VimでPythonプログラミングを快適にするWindows環境の作り方 [gVim/Windows10編]
New Post has been published on https://wp.me/paUJLT-gP
VimでPythonプログラミングを快適にするWindows環境の作り方 [gVim/Windows10編]
VimをWindows 10で利用したいが、なかなか苦労しているというユーザーは多いのでは無いでしょうか。
本記事で、Windows 10 上で gVim を使った快適なプログラミング環境を構築する方法について、ご紹介します。
VimでPythonプログラミングを快適にする構成
下記の構成を前提とした構築���ます。
OS & Python
Windows 10 Professional(執筆時点では バージョン 1903)
Python 2.7.16
Python 3.7.2
なお、Anaconda を活用しても良いとは思います。
ただ、Python 2.7 環境があった方が良いケースがあるようなので、そちらは順番注意です。
Vim
本体&プラグインマネージャー
gVim (KaoriYa版がおすすめ)
プラグインマネージャー:dein
vim.org の vim もアリですが、Kaoriya版の方が色々な組み込みがされているので便利です。
プラグインマネージャーは好みですが、dein が高速でメンテナンスも細やかなので人気があるようです。
プラグイン
プラグインはかなり好みがあると思いますが、今回は下記のようなオーソドックスな構成としています。(それでも数は多いですが…)
deoplete.nvim 入力補完nvim-yarp フレームワーク deoplete.nvim利用のためvim-hug-neovim-rpcフレームワーク deoplete.nvim利用のため denite.nvim検索ツールdefx.nvimファイルマネージャー vim-quickrun簡易実行tagbar概要表示mru.vimファイル履歴表示vim-fugitive.gitGit 操作vim-gitgutterGit 差分表示vim-surround テキスト囲み補完vimdoc-jaヘルプ日本語化vim-auto-save自動保存molokaiカラースキーマindentLineインデント表示lightline.vimステータスバー表示neosnippet.vimスニペットツールneosnippet-snippetsスニペット集vim-tomlTOMLハイライトVimプラグイン設定用途vim-gitignoregitignoreハイライトvim-jsonJSONハイライトPythonでJSONファイルはよく扱うblackPythonフォーマッタvim-flake8Pythonコードチェッカーjedi-vimPython入力支援syntasticPythonシンタックスチェッカーauto-ctags.vim タグ生成 プログラミング時のみ利用
こちらのサイトを参考に、さらに欲しいプラグインを加えると良いでしょう。
Vim Awesome
Awesome Vim plugins from across the universe
vimawesome.com
注意
今回はあくまで gVim 、Windows上の1つのウインドウアプリケーションとして利用する上での構成となります。
そのため、コマンドプロンプトやPowerShellで利用するには、不自由があります。
そちらで利用するには、それに合わせた設定が必要になる点をご理解ください。
Vim環境構築1.前提環境の準備
python2系インストール
必ず先に Python2 系をインストールする必要があります。
こちらからダウンロードして、インストールしましょう。
Python Release Python 2.7.15
The official home of the Python Programming Language
www.python.org
python3系インストール
次に Python3 系のインストールが必要になります。
こちらからダウンロードして、インストールしましょう。
Python Release Python 3.7.2
The official home of the Python Programming Language
www.python.org
必ず Python2 系とは異なるディレクトリにしましょう。
Pythonにパスを通す
詳しい手順は省略しますが、Python3 および Python(2系) のフォルダにパスを通します。
環境変数は ユーザー変数でもシステム変数でもOK
インストーラで設定するなら、そちらでも構いません。必ず設定内容は確認しましょう。
Pythonモジュールのインストール
下記のコマンドで、gVimで利用するモジュールをインストールします。
pip install --upgrade black flake8 flake8-docstrings flake8-import-order hacking flake8-pytest jedi nvim pynvim
コマンドプロンプトは、管理者権限で実行することに注意してください。
Gitインストール
こちらからインストーラを使って、指示通りにインストールします。
Git
git-scm.com
バージョンは最新版で構いませんが、こちらも環境変数のPATHには必ず追加しておきましょう。
Vim環境構築2.Vimインストール
gVim(Kaoriya版)のインストール
こちらから有り難くダウンロードさせていただいて、インストールしましょう。
Vim — KaoriYa
VimのWindows向けコンパイル済みバイナリを配布しています。
www.kaoriya.net
インストーラも無く、解凍して配置するだけで簡単です。
配置場所はどちらでも構いませんが、下記へインストールするのが無難ですね。
C:\Program Files\vim
環境変数のPATHに追加しておくと、かなり便利です。
ctags のインストール
タグファイルを作成するプログラムもインストールしておきます。
ctags日本語対応版
hp.vector.co.jp
こちらも インストーラも無く、解凍して配置するだけです。
PATHが通っていないといけないので、 環境変数のPATHにあるフォルダに配置するのがオススメです。
フォントのインストール
かなり好みの激しいところですが、今回はフォントは次を利用しています。
yuru7/HackGen
HackGen is Japanese programming font which is a composed of Hack and GenJyuu-Gothic. - yuru7/HackGen
github.com
文字が読みやすくて非常に良いですね。こちらの記事で好きになってしまいました。
【文字幅 半角3:全角5 も追加】Ricty を神フォントだと崇める僕が、フリーライセンスのプログラミングフォント「白源」を作った話 - Qiita
**(2019/10/21 Updated)** ユーザさんが、Homebrew リポジトリに白源を追加してくださいました。Mac で Homebrew ユーザの方はご利用ください。 --- 誰もが知る(?)プログラミングフォン...
qiita.com
関連フォルダの作成
下記のコマンドでフォルダを作成しましょう。
mkdir %USERPROFILE%\.vim\backup mkdir %USERPROFILE%\.vim\dein mkdir %USERPROFILE%\.vim\session mkdir %USERPROFILE%\.vim\swap mkdir %USERPROFILE%\.vim\undo
プラグインマネージャーのインストール
プラグインマネージャーだけは手動インストールしなければ、他のプラグインのインストールが機能しません。
そのため、下記のコマンドを実行して下さい。
git clone https://github.com/Shougo/dein.vim.git %USERPROFILE%\.vim\dein
シンプルにするために標準のフォルダとは変更している点は注意です。
Vim環境構築3.Vim設定
配置場所
各設定ファイルの配置場所は下記の通りです。
%USERPROFILE% (ホームフォルダ) | +--- .vimrc +--- .gvimrc +--- .vim/    |    +--- plugins.toml    +--- lazy.toml    +--- backup/    +--- session/    +--- swap    +--- undo    +--- dein
設定ファイル1. .vimrc
こちらを元にさせてもらって、カスタマイズするのが良いですね。
amix/vimrc
The ultimate Vim configuration: vimrc. Contribute to amix/vimrc development by creating an account on GitHub.
github.com
.vimrc は0から構築するのは辞めた方が良いですね。手間がかかりすぎる上に設定漏れが多くなってしまいますので。
"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Sections: " -> General " -> VIM user interface " -> Colors and Fonts " -> Files and backups " -> Text, tab and indent related " -> Visual mode related " -> Moving around, tabs and buffers " -> Status line " -> Editing mappings " -> vimgrep searching and cope displaying " -> Spell checking " -> Misc " -> Helper functions " """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " => General """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Sets how many lines of history VIM has to remember set history=500 " Enable filetype plugins filetype plugin on filetype indent on " Set to auto read when a file is changed from the outside set autoread " With a map leader it's possible to do extra key combinations " like <leader>w saves the current file let mapleader = "," " Fast saving nmap <leader>w :w!<cr> " :W sudo saves the file " (useful for handling the permission-denied error) command W w !sudo tee % > /dev/null """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " => VIM user interface """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Set 7 lines to the cursor - when moving vertically using j/k set so=7 " Avoid garbled characters in Chinese language windows OS let $LANG='ja' set langmenu=ja source $VIMRUNTIME/delmenu.vim source $VIMRUNTIME/menu.vim " Turn on the Wild menu set wildmenu " Ignore compiled files set wildignore=*.o,*~,*.pyc if has("win16") || has("win32") set wildignore+=.git\*,.hg\*,.svn\* else set wildignore+=*/.git/*,*/.hg/*,*/.svn/*,*/.DS_Store endif "Always show current position set ruler " Height of the command bar set cmdheight=2 " A buffer becomes hidden when it is abandoned set hid " Configure backspace so it acts as it should act set backspace=eol,start,indent set whichwrap+=<,>,h,l " Ignore case when searching set ignorecase " When searching try to be smart about cases set smartcase " Highlight search results set hlsearch " Makes search act like search in modern browsers set incsearch " Don't redraw while executing macros (good performance config) set lazyredraw " For regular expressions turn magic on set magic " Show matching brackets when text indicator is over them set showmatch " How many tenths of a second to blink when matching brackets set mat=2 " No annoying sound on errors set noerrorbells set novisualbell set t_vb= set tm=500 " Properly disable sound on errors on MacVim if has("gui_macvim") autocmd GUIEnter * set vb t_vb= endif " Add a bit extra margin to the left set foldcolumn=1 " === Add Settings == set belloff=all set vb t_vb= set showcmd set wrapscan set matchtime=3 set list set autoindent set hidden set ttyfast set number set mousemodel=popup set mouse=a if has("win16") || has("win32") set clipboard& set clipboard=unnamed else set clipboard& set clipboard^=unnamedplus endif set cursorline " ファイルを開くと、ファイルがあるディレクトリに移動する augroup grlcd autocmd! autocmd BufEnter * if &buftype !=# 'terminal' | lcd %:p:h | endif augroup END """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " => Colors and Fonts """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Enable syntax highlighting syntax enable " Enable 256 colors palette in Gnome Terminal if $COLORTERM == 'gnome-terminal' set t_Co=256 endif try colorscheme evening catch endtry set background=dark " Set extra options when running in GUI mode if has("gui_running") "set guioptions-=T "set guioptions-=e " === Add: Display: toolbar and menubar === set guioptions=egmrtiT set t_Co=256 set guitablabel=%M\ %t endif " Set utf8 as standard encoding and en_US as the standard language set encoding=utf8 " Use Unix as the standard file type set ffs=unix,dos,mac " === Add: file encodings === set fileencoding=utf-8 set fileencodings=utf-8,iso-2022-jp,euc-jp,sjis " === Add: Colorcolum === set colorcolumn=80 " """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " => Files, backups and undo """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Turn backup off, since most stuff is in SVN, git et.c anyway... set nobackup set nowb set noswapfile """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " => Text, tab and indent related """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Use spaces instead of tabs set expandtab " Be smart when using tabs ;) set smarttab " 1 tab == 4 spaces set shiftwidth=4 set tabstop=4 " === Add: set softtabstop=0 " Linebreak on 500 characters set lbr set tw=500 set ai "Auto indent set si "Smart indent set wrap "Wrap lines """""""""""""""""""""""""""""" " => Visual mode related """""""""""""""""""""""""""""" " Visual mode pressing * or # searches for the current selection " Super useful! From an idea by Michael Naumann vnoremap <silent> * :<C-u>call VisualSelection('', '')<CR>/<C-R>=@/<CR><CR> vnoremap <silent> # :<C-u>call VisualSelection('', '')<CR>?<C-R>=@/<CR><CR> """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " => Moving around, tabs, windows and buffers """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Map <Space> to / (search) and Ctrl-<Space> to ? (backwards search) map <space> / map <c-space> ? " Disable highlight when <leader><cr> is pressed map <silent> <leader><cr> :noh<cr> " Smart way to move between windows map <C-j> <C-W>j map <C-k> <C-W>k map <C-h> <C-W>h map <C-l> <C-W>l " Close the current buffer map <leader>bd :Bclose<cr>:tabclose<cr>gT " Close all the buffers map <leader>ba :bufdo bd<cr> map <leader>l :bnext<cr> map <leader>h :bprevious<cr> " Useful mappings for managing tabs map <leader>tn :tabnew<cr> map <leader>to :tabonly<cr> map <leader>tc :tabclose<cr> map <leader>tm :tabmove map <leader>t<leader> :tabnext " Let 'tl' toggle between this and the last accessed tab let g:lasttab = 1 nmap <Leader>tl :exe "tabn ".g:lasttab<CR> au TabLeave * let g:lasttab = tabpagenr() " Opens a new tab with the current buffer's path " Super useful when editing files in the same directory map <leader>te :tabedit <c-r>=expand("%:p:h")<cr>/ " Switch CWD to the directory of the open buffer map <leader>cd :cd %:p:h<cr>:pwd<cr> " Specify the behavior when switching between buffers try set switchbuf=useopen,usetab,newtab set stal=2 catch endtry " Return to last edit position when opening files (You want this!) au BufReadPost * if line("'\"") > 1 && line("'\"") <= line("$") | exe "normal! g'\"" | endif """""""""""""""""""""""""""""" " => Status line """""""""""""""""""""""""""""" " Always show the status line set laststatus=2 " Format the status line " set statusline=\ %HasPaste()%F%m%r%h\ %w\ \ CWD:\ %r%getcwd()%h\ \ \ Line:\ %l\ \ Column:\ %c set laststatus=2 set statusline=%<%f\ %m%r%h%w%'['.(&fenc!=''?&fenc:&enc).']['.&ff.']'%=%l,%c%V%8P """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " => Editing mappings """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Remap VIM 0 to first non-blank character map 0 ^ " Move a line of text using ALT+[jk] or Command+[jk] on mac nmap <M-j> mz:m+<cr>`z nmap <M-k> mz:m-2<cr>`z vmap <M-j> :m'>+<cr>`<my`>mzgv`yo`z vmap <M-k> :m'<-2<cr>`>my`<mzgv`yo`z if has("mac") || has("macunix") nmap <D-j> <M-j> nmap <D-k> <M-k> vmap <D-j> <M-j> vmap <D-k> <M-k> endif " Delete trailing white space on save, useful for some filetypes ;) fun! CleanExtraSpaces() let save_cursor = getpos(".") let old_query = getreg('/') silent! %s/\s\+$//e call setpos('.', save_cursor) call setreg('/', old_query) endfun if has("autocmd") autocmd BufWritePre *.txt,*.js,*.py,*.wiki,*.sh,*.coffee :call CleanExtraSpaces() endif """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " => Spell checking """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Pressing ,ss will toggle and untoggle spell checking map <leader>ss :setlocal spell!<cr> " Shortcuts using <leader> map <leader>sn ]s map <leader>sp [s map <leader>sa zg map <leader>s? z= """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " => Misc """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Remove the Windows ^M - when the encodings gets messed up noremap <Leader>m mmHmt:%s/<C-V><cr>//ge<cr>'tzt'm " Quickly open a buffer for scribble map <leader>q :e ~/buffer<cr> " Quickly open a markdown buffer for scribble map <leader>x :e ~/buffer.md<cr> " Toggle paste mode on and off map <leader>pp :setlocal paste!<cr> """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " => Helper functions """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Returns true if paste mode is enabled function! HasPaste() if &paste return 'PASTE MODE ' endif return '' endfunction " Don't close window, when deleting a buffer command! Bclose call <SID>BufcloseCloseIt() function! <SID>BufcloseCloseIt() let l:currentBufNum = bufnr("%") let l:alternateBufNum = bufnr("#") if buflisted(l:alternateBufNum) buffer # else bnext endif if bufnr("%") == l:currentBufNum new endif if buflisted(l:currentBufNum) execute("bdelete! ".l:currentBufNum) endif endfunction function! CmdLine(str) call feedkeys(":" . a:str) endfunction function! VisualSelection(direction, extra_filter) range let l:saved_reg = @" execute "normal! vgvy" let l:pattern = escape(@", "\\/.*'$^~[]") let l:pattern = substitute(l:pattern, "\n$", "", "") if a:direction == 'gv' call CmdLine("Ack '" . l:pattern . "' " ) elseif a:direction == 'replace' call CmdLine("%s" . '/'. l:pattern . '/') endif let @/ = l:pattern let @" = l:saved_reg endfunction """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " => Directory Settings """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Valuable definition let g:vimdir = $HOME . '\.vim' let g:bundledir = vimdir . '\bundle' let g:session_directory = vimdir . '\session' let g:vimproc#download_windows_dll = 1 let $VIMDIR = vimdir set backupdir=$VIMDIR/backup set directory=$VIMDIR/swap set undodir=$VIMDIR/undo set updatetime=60000 " session management let g:session_autoload = "no" let g:session_autosave = "no" let g:session_command_aliases = 1 let g:python3_host_prog = 'C:\Program Files\Python37\python.exe' """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" "" dein Settings """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" if &compatible set nocompatible endif " dein directories "let s:dein_dir = expand($VIMDIR . '\dein') let g:dein_dir = $VIMDIR . '\dein' let g:dein_repo_dir = g:dein_dir let g:dein#cache_directory = g:dein_dir set runtimepath+=$VIMDIR\dein " Required: if dein#load_state(g:dein_dir) call dein#begin(g:dein_dir) call dein#add('$HOME') call dein#add('Shougo/deoplete.nvim') if !has('nvim') call dein#add('roxma/nvim-yarp') call dein#add('roxma/vim-hug-neovim-rpc') endif let g:deoplete#enable_at_startup = 1 "let g:config_dir = expand('~\.cache\nvim') let g:config_dir = $VIMDIR let s:toml = g:config_dir . '\plugins.toml' let s:lazy_toml = g:config_dir . '\lazy.toml' call dein#load_toml(s:toml, 'lazy': 0) call dein#load_toml(s:lazy_toml, 'lazy': 1) call dein#end() call dein#save_state() endif " If you want to install not installed plugins on startup. if dein#check_install() call dein#install() endif filetype plugin indent on """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" "" Key Mappings """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Like windows keymapping inoremap <C-v> <C-r>* inoremap <C-e> <End> nnoremap <C-c> "+y vnoremap <C-C> "+y nnoremap <C-a> ggVG " Tab control nnoremap <C-t> :tabe<cr> nnoremap <C-tab> :tabnext<cr> nnoremap <C-S-tab> :tabprevious<cr> " Edit / source setting files nnoremap <F5> :source $MYVIMRC<CR> nnoremap <C-F7> :<C-u>split $MYVIMRC<CR> nnoremap <C-F8> :<C-u>split $HOME\.vim\plugins.toml<CR> nnoremap <C-F9> :<C-u>split $HOME\.vim\lazy.toml<CR> nnoremap <S-F7> :<C-u>edit $MYVIMRC<CR> nnoremap <S-F8> :<C-u>edit $HOME\.vim\plugins.toml<CR> nnoremap <S-F9> :<C-u>edit $HOME\.vim\lazy.toml<CR> " Programmings nnoremap <C-F5> :bo terminal<CR> nnoremap <C-A-F5> :QuickRun<CR> nnoremap <C-e> <End> " Launch Plugins nnoremap <F1> :MRU<CR> nnoremap <F2> :Denite buffer<CR> nnoremap <F3> :Denite file/rec<CR> nnoremap <F4> :Denite file/rec -input= nnoremap <F7> :Defx -split -columns=icons:indent:filename:type<CR> nnoremap <F8> :Defx -split=vertical -winwidth=30<CR> nnoremap <F9> :TagbarToggle<CR> " deoplete inoremap <expr><tab> pumvisible() ? "\<C-n>" : \ neosnippet#expandable_or_jumpable() ? \ "\<Plug>(neosnippet_expand_or_jump)" : "\<tab>"
それぞれの詳しい説明は、各プラグインの説明ページに譲ります。
ただ、Windows らしいキー操作を残しつつ、Denite や Defx などの頻繁に使う機能はファンクションキーに割り当てたのは拘りのポイントです。
また、deoplete.nvim はプラグインの設定ファイルに記載すると競合するみたいなので、コチラに記載することにしました。ちょっと格好悪いですが…
設定ファイル2. .gvimrc
gVimを利用するときだけの設定ファイルで、主にGUI周りの設定のみ切り出しています。
""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" "" Visual Settings """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" " Window set columns=80 " ウインドウ幅 set lines=52 " ウインドウ高 if has("gui") winpos 0 0 " ウインドウ位置 endif source $VIMRUNTIME/delmenu.vim set langmenu=ja_jp.utf-8 source $VIMRUNTIME/menu.vim set guifont=HackGen:h12 colorscheme molokai
このファイルが無いと、Windowsでは動作してくれないところがあるため、やむなく .vimrc と併用して利用することになります。
設定ファイル3. plugin.toml(プラグイン)
gVim起動時に一緒に読み込むプラグインを設定します。
ポイントは、denite と defx のキーバインド設定と indentLine の設定です。
特に、前者は設定しないと正常にりようできないので最低限といえる内容です。
[[plugins]] repo = 'Shougo/denite.nvim' on_cmd = 'Denite' hook_add = ''' " Define mappings autocmd FileType denite call s:denite_my_settings() function! s:denite_my_settings() abort nnoremap <silent><buffer><expr> <CR> \ denite#do_map('do_action') nnoremap <silent><buffer><expr> d \ denite#do_map('do_action', 'delete') nnoremap <silent><buffer><expr> p \ denite#do_map('do_action', 'preview') nnoremap <silent><buffer><expr> q \ denite#do_map('quit') nnoremap <silent><buffer><expr> i \ denite#do_map('open_filter_buffer') nnoremap <silent><buffer><expr> <Space> \ denite#do_map('toggle_select').'j' endfunction autocmd FileType denite-filter call s:denite_filter_my_settings() function! s:denite_filter_my_settings() abort imap <silent><buffer> <C-o> <Plug>(denite_filter_quit) endfunction ''' [[plugins]] repo = 'Shougo/defx.nvim' on_cmd = 'Defx' hook_add = ''' set runtimepath+=~/.vim/dein/repos/github.com/Shougo/defx.nvim/ autocmd FileType defx call s:defx_my_settings() function! s:defx_my_settings() abort " Define mappings nnoremap <silent><buffer><expr> <CR> \ defx#do_action('open') nnoremap <silent><buffer><expr> c \ defx#do_action('copy') nnoremap <silent><buffer><expr> m \ defx#do_action('move') nnoremap <silent><buffer><expr> p \ defx#do_action('paste') nnoremap <silent><buffer><expr> l \ defx#do_action('open') nnoremap <silent><buffer><expr> E \ defx#do_action('open', 'vsplit') nnoremap <silent><buffer><expr> P \ defx#do_action('open', 'pedit') nnoremap <silent><buffer><expr> o \ defx#do_action('open_or_close_tree') nnoremap <silent><buffer><expr> K \ defx#do_action('new_directory') nnoremap <silent><buffer><expr> N \ defx#do_action('new_file') nnoremap <silent><buffer><expr> M \ defx#do_action('new_multiple_files') nnoremap <silent><buffer><expr> C \ defx#do_action('toggle_columns', \ 'mark:indent:icon:filename:type:size:time') nnoremap <silent><buffer><expr> S \ defx#do_action('toggle_sort', 'time') nnoremap <silent><buffer><expr> d \ defx#do_action('remove') nnoremap <silent><buffer><expr> r \ defx#do_action('rename') nnoremap <silent><buffer><expr> ! \ defx#do_action('execute_command') nnoremap <silent><buffer><expr> x \ defx#do_action('execute_system') nnoremap <silent><buffer><expr> yy \ defx#do_action('yank_path') nnoremap <silent><buffer><expr> . \ defx#do_action('toggle_ignored_files') nnoremap <silent><buffer><expr> ; \ defx#do_action('repeat') nnoremap <silent><buffer><expr> h \ defx#do_action('cd', ['..']) nnoremap <silent><buffer><expr> ~ \ defx#do_action('cd') nnoremap <silent><buffer><expr> q \ defx#do_action('quit') nnoremap <silent><buffer><expr> <Space> \ defx#do_action('toggle_select') . 'j' nnoremap <silent><buffer><expr> * \ defx#do_action('toggle_select_all') nnoremap <silent><buffer><expr> j \ line('.') == line('$') ? 'gg' : 'j' nnoremap <silent><buffer><expr> k \ line('.') == 1 ? 'G' : 'k' nnoremap <silent><buffer><expr> <C-l> \ defx#do_action('redraw') nnoremap <silent><buffer><expr> <C-g> \ defx#do_action('print') nnoremap <silent><buffer><expr> cd \ defx#do_action('change_vim_cwd') endfunction ''' [[plugins]] repo = 'thinca/vim-quickrun' [[plugins]] repo = 'majutsushi/tagbar' [[plugins]] repo = 'vim-scripts/mru.vim' [[plugins]] repo = 'tpope/vim-fugitive.git' [[plugins]] repo = 'airblade/vim-gitgutter' hook_add = ''' let g:gitgutter_git_executable = 'C:\Program Files\Git\cmd\git.exe' ''' [[plugins]] repo = 'tpope/vim-surround' [[plugins]] repo = 'vim-jp/vimdoc-ja' [[plugins]] repo = 'vim-scripts/vim-auto-save' [[plugins]] repo = 'tomasr/molokai' hook_add = ''' colorscheme molokai set t_Co=256 let g:molokai_original = 1 let g:rehash256 = 1 if has('gui_running') set background=dark else set background=light endif ''' [[plugins]] repo = 'Yggdroot/indentLine' hook_add = ''' let g:indent_guides_enable_on_vim_startup = 1 let g:indent_guides_start_level = 2 let g:indent_guides_guide_size = 1 let g:indent_guides_exclude_filetypes = ['help', 'nerdtree', 'tagbar', 'unite'] ''' [[plugins]] repo = 'itchyny/lightline.vim'
設定ファイル4. lazy.toml(遅延読み込みプラグイン)
プラグインの機能を使いたいときだけ読み込む設定です。
可能な限り、こちらに移せば gVim の起動動作が速くなるので良いですが、機能を使うときには都度読み込みが発生します。
主にプログラミング作業に使用するプラグインなど、使う場面が特定できそうなものを中心に設定しています。
[[plugins]] repo = 'Shougo/neosnippet.vim' on_i = 1 on_ft = ['snippet'] depends = ['neosnippet-snippets'] hook_add = ''' let g:neosnippet#snippets_directory = '$HOME/.vim/snippets/' imap <C-K> <Plug>(neosnippet_expand_or_jump) smap <C-K> <Plug>(neosnippet_expand_or_jump) xmap <C-K> <Plug>(neosnippet_expand_target) if has('conceal') set conceallevel=2 concealcursor=niv endif ''' [[plugins]] repo = 'Shougo/neosnippet-snippets' [[plugins]] repo = 'cespare/vim-toml' on_ft = ['toml'] [[plugins]] repo = 'gisphm/vim-gitignore' on_ft = ['gitignore'] [[plugins]] repo = 'elzr/vim-json' on_ft = ['json'] hook_add = ''' let g:vim_json_syntax_conceal = 0 au! BufRead,BufNewFile *.json set filetype=json augroup json_autocmd autocmd! autocmd FileType json set autoindent autocmd FileType json set formatoptions=tcq2l autocmd FileType json set textwidth=78 shiftwidth=2 autocmd FileType json set softtabstop=2 tabstop=8 autocmd FileType json set expandtab autocmd FileType json set foldmethod=syntax augroup END ''' # Python plugins """""""""""""""""""""""""""""""""""""""""""""" [[plugins]] repo = 'psf/black' on_ft = ['python'] hook_add = ''' autocmd BufWritePost *.py Black ''' [[plugins]] repo = 'nvie/vim-flake8' on_ft = ['python'] hook_add = ''' autocmd BufWritePost *.py call Flake8() let g:flake8_show_in_gutter=1 let g:flake8_show_in_file=1 ''' [[plugins]] repo = 'davidhalter/jedi-vim' on_ft = ['python'] [[plugins]] repo = 'vim-scripts/syntastic' on_ft = ['python'] [[plugins]] repo = 'soramugi/auto-ctags.vim' on_ft = ['python'] hook_add = ''' let g:auto_ctags = 1 let g:auto_ctags_directory_list = ['.git', '.'] '''
これまでの手順がすべて完了していれば、次回の gVim 起動時に必要なプラグインが git によってインストールされます。
その際は、少し gVimの起動に時間がかかる点は注意してください。
以上で、インストールおよび初期設定は完了です。
Python スクリプトをチェッカーでチェックした様子
しかし、Windows環境で快適に使うなら、あと一工夫が必要です。
Windows環境で素早くVimを利用するために
スタートメニュー/タスクバー
Windows の基本ですが、gVim をスタートメニューやタスクバーに登録しましょう。
gVim(kaoriya版)にはインストーラーが無いため、手動で登録する必要がある点は注意です。
ショートカットキーの設定
とっさにパッと起動したいことがあり得ます。そんな時にはショートカットキーを使うと便利です。
こちらの画像をご覧いただくと分かりますが、gVim のショートカットのプロパティに設定します。
タスクバーに登録した gVim のショートカットのプロパティに設定したりすると良いですね。
右クリックメニュー
こちらの手順の通り、Windowsの右クリックメニューに追加すると、さらにgVimを利用しやすくなりますので、オススメです。
GVim/neovimの右クリックメニュー登録方法 [Windows 10]
この記事では、GVim / neovim を Windows 10 の右クリックメニューへ登録する方法をご紹介します。
vim.blue
2019.10.13
「送る」への追加
右クリックメニューの「送る」に登録する手もあります。
レジストリを操作しなくて良いので安全ですが、選ぶためには1つステップが増えます。
もしこちらを設定する場合は、窓キー+Rキーを押した後に下記のコマンドを実行してください。
shell:sendto
コマンドプロンプトからは実行できないので要注意。
以上で gVim を Windows環境に馴染ませて、Python開発ができる環境が整いました。
動作確認としては、下記をやってみると良いと思います。
Terminal モードで Python を起動する
QuickRun で Pythonスクリプトを実行する
:py または py3 でそれぞれスクリプトを実行する(バージョン注意)
:!python % または :!python3 % でスクリプトを実行する (バージョン注意)
Pythonスクリプトを保存する(各チェッカーやフォーマッターが機能するはず)
既知の問題
この手順で設定した gVim には下記の問題があります。ご理解ください。
TOMLファイルを読み込んだ際、ハイライトが機能しない。(その後、source $MYVIMRC するとハイライトが機能します)
同じ設定ファイルで、コマンドプロンプトから Vim を起動すると、ステータスバーの設定など正常に機能しません。
Pythonスクリプトを保存する際、jedi や フォーマッター、チェッカーがエラーを起こすことがあります。
また、解決法が分かる方は、お問い合わせフォームもしくはTwitterでメンションいただけると助かります。
Pythonプログラミングのレベルアップには
Python プログラミングを学びたい Vimmer は、次のようなオンラインスクールを活用するのが良いでしょう。通いのスクールが難しい人に最適です。
Udemy
有名オンラインレッスンサービスです。コンテンツが非常に充実しており、プログラミングに限らないバリエーションの豊富さが特徴です。
プログラミング言語 Python 3 入門 プログラミング初心者でも安心、Python/Django入門講座 【4日で体験!】 TensorFlow, Keras, Python 3 で学ぶディープラーニング体験講座 Python 3 : Web スクレイピング 超入門 - Python で通販サイトの最低価格を比較するアプリを作る
日本語以外ができるのであれば、より選択肢が多いサイトといえます。
質の高い動画での学習は、多くのエンジニアに好評を得ていますね。
TechAcademy
国内のプログラミングスクールでは、定評のあるサービスの1つです。
オンラインブートキャンプをうたっているだけあって、かなりミッチリなカリキュラムが評判です。
また、パーソナルメンターがつくなど、挫折しにくく、徹底的なサポートが魅力です。
Pythonコースなら「機械学習プログラムを開発することがゴール」とされているのも面白いですね。
無料レッスンもやっているようなので、機械学習を学びたい人をはじめ、Pythonプログラミングを覚えたい人は、ぜひ試してみると良いでしょう。
CodeCamp
国内のプログラミングスクールでは、定評のあるサービ���の1つです。
講師陣が現役エンジニアであることや、講師との1on1レッスンが好評です。
プログラミングのオンライン家庭教師と表するサービスは、なかなか魅力的ではないでしょうか。
また、「Pythonデータサイエンスコース」では、Pythonで業務タスクを自動化する方法も学べるようです。
こちらも無料レッスンもやっているようなのですので、ぜひ試してみると良いでしょう。
0 notes
jeeteshsurana · 5 years
Link
Get Contact list in android studio kotlin
_____________________________________________________________________
Helper Class
_______________________________________________________________________
class ContactHelper(val context: Context) : LoaderManager.LoaderCallbacks<Cursor> {
    private lateinit var mLoadContactComplete: ContactLoadComplete
    private var mArrayList = ArrayList<ContactList>()
    private var mNameArrayList = ArrayList<String>()
    companion object {
        val projection = arrayOf(ContactsContract.Data.MIMETYPE, ContactsContract.Data.CONTACT_ID, ContactsContract.Contacts.DISPLAY_NAME, ContactsContract.CommonDataKinds.Contactables.DATA, ContactsContract.CommonDataKinds.Contactables.TYPE, ContactsContract.Contacts.HAS_PHONE_NUMBER)
        val selection = ContactsContract.Data.MIMETYPE + " in (?, ?)"
        val selectionArgs = arrayOf(ContactsContract.CommonDataKinds.Email.CONTENT_ITEM_TYPE, ContactsContract.CommonDataKinds.Phone.CONTENT_ITEM_TYPE)
        val sortOrder = ContactsContract.Contacts.SORT_KEY_ALTERNATIVE
        val uri = ContactsContract.CommonDataKinds.Contactables.CONTENT_URI
    }
    fun getAllContacts(mFragment: Fragment, loadContactComplete: ContactLoadComplete) {
        mLoadContactComplete = loadContactComplete
        LoaderManager.getInstance(mFragment).initLoader(0, null, this)
    }
    override fun onCreateLoader(id: Int, args: Bundle?): Loader<Cursor> {
        return CursorLoader(context, uri, projection, selection, selectionArgs, sortOrder)
    }
    @SuppressLint("ObsoleteSdkInt")
    override fun onLoadFinished(loader: Loader<Cursor>, cursor: Cursor?) {
        Log.e("onLoadFinished-->", "onLoadFinished-->")
        if (cursor != null && !cursor.isClosed) {
            mArrayList.clear()
            while (cursor.moveToNext()) {
                val id = cursor.getLong(cursor.getColumnIndex(ContactsContract.Data.CONTACT_ID))
                val name = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME_PRIMARY))
                var hasPhone = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.HAS_PHONE_NUMBER))
                hasPhone = if (hasPhone.equals("1", ignoreCase = true)) "true"
                else "false"
                if (!mNameArrayList.contains(name)) {
                    mNameArrayList.add(name)
                    if (hasPhone.equals("true", true)) {
                        val mPhoneList = PhoneList()
                        val data = cursor.getColumnIndex(ContactsContract.CommonDataKinds.Contactables.DATA)
                        mPhoneList.phoneNumber = data.toString()
                        mPhoneList.id = id
                        mPhoneList.name = name
                        mPhoneList.hasPhone = hasPhone.toBoolean()
                        mPhoneList.imagePath = getPhotoUri(context, id).toString()
                        mArrayList.add(mPhoneList)
                    }
                }
            }
            cursor.close()
            mLoadContactComplete.getAllContact(mArrayList, mNameArrayList)
        }
    }
    @SuppressLint("Recycle")
    private fun getPhotoUri(context: Context, id: Long): Uri? {
        val person = ContentUris.withAppendedId(ContactsContract.Contacts.CONTENT_URI, id)
        return Uri.withAppendedPath(person, ContactsContract.Contacts.Photo.CONTENT_DIRECTORY)
    }
    override fun onLoaderReset(loader: Loader<Cursor>) {
    }
    interface ContactLoadComplete {
        fun getAllContact(mContactArrayList: ArrayList<ContactList>, mNameArrayList: ArrayList<String>)
    }
}
_______________________________________________________________________
Model Class
_______________________________________________________________________
open class ContactList(var id: Long = 0, var name: String = "", var hasPhone: Boolean = false, var path: String = "", var imagePath: String = "", var isInvite: Boolean = false)
class PhoneList(var phoneId:String="",var phoneNumber:String="") : ContactList()
_______________________________________________________________________
implementation
_______________________________________________________________________
 ContactHelper(mContext).getAllContacts(mFragment, object : ContactHelper.ContactLoadComplete {
            override fun getAllContact(mContactArrayList: ArrayList<ContactList>, mNameArrayList: ArrayList<String>) {
               //code here
            }
        })
_______________________________________________________________________
0 notes
phptutorialforyou · 6 years
Photo
Tumblr media
@phpc : RT @s_bergmann: Do you use @phpunit's assertEquals() with one of its optional parameters $maxDepth, $canonicalize, or $ignoreCase? If so, please have a look at https://t.co/9MPRVgocJw and provide feedback. Thanks!
0 notes
maphyorg · 6 years
Text
正则表达式30分钟入门教程
本文目标
30分钟内让你明白正则表达式是什么,并对它有一些基本的了解,让你可以在自己的程序或网页里使用它。
如何使用本教程
别被下面那些复杂的表达式吓倒,只要跟着我一步一步来,你会发现正则表达式其实并没有想像中的那么困难。当然,如果你看完了这篇教程之后,发现自己明白了很多,却又几乎什么都记不得,那也是很正常的——我认为,没接触过正则表达式的人在看完这篇教程后,能把提到过的语法记住80%以上的可能性为零。这里只是让你明白基本的原理,以后你还需要多练习,多使用,才能熟练掌握正则表达式。
除了作为入门教程之外,本文还试图成为可以在日常工作中使用的正则表达式语法参考手册。就作者本人的经历来说,这个目标还是完成得不错的——你看,我自己也没能把所有的东西记下来,不是吗?
文本格式约定: 专业术语 元字符/语法格式 正则表达式 正则表达式中的一部分(用于分析) 对其进行匹配的源字符串 对正则表达式或其中一部分的说明
正则表达式到底是什么东西?
在编写处理字符串的程序或网页时,经常会有查找符合某些复杂规则的字符串的需要。正则表达式就是用于描述这些规则的工具。换句话说,正则表达式就是记录文本规则的代码。
很可能你使用过Windows/Dos下用于文件查找的通配符(wildcard) ,也就是 和? 。如果你想查找某个目录下的所有的Word文档的话,你会搜索.doc 。在这里, * 会被解释成任意的字符串。和通配符类似,正则表达式也是用来进行文本匹配的工具,只不过比起通配符,它能更精确地描述你的需求——当然,代价就是更复杂——比如你可以编写一个正则表达式,用来查找所有以0开头,后面跟着2-3个数字,然后是一个连字号“-”,最后是7或8位数字的字符串(像010-12345678或 0376-7654321 )。
入门
学习正则表达式的最好方法是从例子开始,理解例子之后再自己对例子进行修改,实验。下面给出了不少简单的例子,并对它们作了详细的说明。
假设你在一篇英文小说里查找hi,你可以使用正则表达式hi。
这几乎是最简单的正则表达式了,它可以精确匹配这样的字符串:由两个字符组成,前一个字符是h,后一个是i。通常,处理正则表达式的工具会提供一个忽略大小写的选项,如果选中了这个选项,它可以匹配hi,HI,Hi,hI这四种情况中的任意一种。
不幸的是,很多单词里包含hi这两个连续的字符,比如him,history,high等等。用hi来查找的话,这里边的hi也会被找出来。如果要精确地查找hi这个单词的话,我们应该使用\bhi\b。
\b是正则表达式规定的一个特殊代码(好吧,某些人叫它元字符,metacharacter),代表着单词的开头或结尾,也就是单词的分界处。虽然通常英文的单词是由空格,标点符号或者换行来分隔的,但是\b并不匹配这些单词分隔字符中的任何一个,它只匹配一个位置。
如果需要更精确的说法,\b匹配这样的位置:它的前一个字符和后一个字符不全是(一个是,一个不是或不存在)\w。
假如你要找的是hi后面不远处跟着一个Lucy,你应该用\bhi\b.*\bLucy\b。
这里,.是另一个元字符,匹配除了换行符以外的任意字符。同样是元字符,不过它代表的不是字符,也不是位置,而是数量——它指定前边的内容可以连续重复使用任意次以使整个表达式得到匹配。因此,.连在一起就意味着任意数量的不包含换行的字符。现在\bhi\b.\bLucy\b的意思就很明显了:先是一个单词hi,然后是任意个任意字符(但不能是换行),最后是Lucy这个单词。
换行符就是’\n’,ASCII编码为10(十六进制0x0A)的字符。
如果同时使用其它元字符,我们就能构造出功能更强大的正则表达式。比如下面这个例子:
0\d\d-\d\d\d\d\d\d\d\d匹配这样的字符串:以0开头,然后是两个数字,然后是一个连字号“-”,最后是8个数字(也就是中国的电话号码。当然,这个例子只能匹配区号为3位的情形)。
这里的\d是个新的元字符,匹配一位数字(0,或1,或2,或……)。-不是元字符,只匹配它本身——连字符(或者减号,或者中横线,或者随你怎么称呼它)。
为了避免那么多烦人的重复,我们也可以这样写这个表达式:0\d{2}-\d{8}。这里\d后面的{2}({8})的意思是前面\d必须连续重复匹配2次(8次)。
测试正则表达式
如果你不觉得正则表达式很难读写的话,要么你是一个天才,要么,你不是地球人。正则表达式的语法很令人头疼,即使对经常使用它的人来说也是如此。由于难于读写,容易出错,所以找一种工具对正则表达式进行测试是很有必要的。
不同的环境下正则表达式的一些细节是不相同的,本教程介绍的是微软.Net Framework 4.5 下正则表达式的行为,所以,向你推荐.Net下的工具 Regester。请参考该页面的说明来安装和运行该软件。
下面是Regester运行时的截图:
其它可用的测试工具:
RegexBuddy
Javascript正则表达式在线测试工具
元字符
现在你已经知道几个很有用的元字符了,如\b,.,*,还有\d.正则表达式里还有更多的元字符,比如\s匹配任意的空白符,包括空格,制表符(Tab),换行符,中文全角空格等。\w匹配字母或数字或下划线或汉字等。
下面来看看更多的例子:
\ba\w\b匹配以字母a开头的单词——先是某个单词开始处(\b),然后是字母a,然后是任意数量的字母或数字(\w),最后是单词结束处(\b)。
\d+匹配1个或更多连续的数字。这里的+是和类似的元字符,不同的是匹配重复任意次(可能是0次),而+则匹配重复1次或更多次。
\b\w{6}\b匹配刚好6个字符的单词。
表1.常用的元字符
代码 说明 . 匹配除换行符以外的任意字符 \w 匹配字母或数字或下划线或汉字 \s 匹配任意的空白符 \d 匹配数字 \b 匹配单词的开始或结束 ^ 匹配字符串的开始 $ 匹配字符串的结束
元字符^(和数字6在同一个键位上的符号)和$都匹配一个位置,这和\b有点类似。^匹配你要用来查找的字符串的开头,$匹配结尾。这两个代码在验证输入的内容时非常有用,比如一个网站如果要求你填写的QQ号必须为5位到12位数字时,可以使用:^\d{5,12}$。
这里的{5,12}和前面介绍过的{2}是类似的,只不过{2}匹配只能不多不少重复2次,{5,12}则是重复的次数不能少于5次,不能多于12次,否则都不匹配。
因为使用了^和$,所以输入的整个字符串都要用来和\d{5,12}来匹配,也就是说整个输入必须是5到12个数字,因此如果输入的QQ号能匹配这个正则表达式的话,那就符合要求了。
和忽略大小写的选项类似,有些正则表达式处理工具还有一个处理多行的选项。如果选中了这个选项,^和$的意义就变成了匹配行的开始处和结束处。
正则表达式引擎通常会提供一个“测试指定的字符串是否匹配一个正则表达式”的方法,如JavaScript里的RegExp.test()方法或.NET里的Regex.IsMatch()方法。这里的匹配是指是字符串里有没有符合表达式规则的部分。如果不使用^和$的话,对于\d{5,12}而言,使用这样的方法就只能保证字符串里包含5到12连续位数字,而不是整个字符串就是5到12位数字。
字符转义
如果你想查找元字符本身的话,比如你查找.,或者*,就出现了问题:你没办法指定它们,因为它们会被解释成别的意思。这时你就得使用\来取消这些字符的特殊意义。因此,你应该使用.和*。当然,要查找\本身,你也得用\.
例如:deerchao.net匹配deerchao.net,C:\Windows匹配C:\Windows。
重复
你已经看过了前面的,+,{2},{5,12}这几个匹配重复的方式了。下面是正则表达式中所有的限定符(指定数量的代码,例如,{5,12}等):
表2.常用的限定符
代码/语法 说明 * 重复零次或更多次 + 重复一次或更多次 ? 重复零次或一次 {n} 重复n次 {n,} 重复n次或更多次 {n,m} 重复n到m次
下面是一些使用重复的例子:
Windows\d+ 匹配Windows后面跟1个或更多数字
^\w+ 匹配一行的第一个单词(或整个字符串的第一个单词,具体匹配哪个意思得看选项设置)
字符类
要想查找数字,字母或数字,空白是很简单的,因为已经有了对应这些字符集合的元字符,但是如果你想匹配没有预定义元字符的字符集合(比如元音字母a,e,i,o,u),应该怎么办?
很简单,你只需要在方括号里列出它们就行了,像[aeiou]就匹配任何一个英文元音字母,[.?!]匹配标点符号(.或?或!)。
我们也可以轻松地指定一个字符范围,像[0-9]代表的含意与\d就是完全一致的:一位数字;同理[a-z0-9A-Z_]也完全等同于\w(如果只考虑英文的话)。
“(”和“)”也是元字符,后面的分组节里会提到,所以在这里需要使用转义。
下面是一个更复杂的表达式:(?0\d{2}[)-]?\d{8}。
这个表达式可以匹配几种格式的电话号码,像(010)88886666,或022-22334455,或02912345678等。我们对它进行一些分析吧:首先是一个转义字符(,它能出现0次或1次(?),然后是一个0,后面跟着2个数字(\d{2}),然后是)或-或空格中的一个,它出现1次或不出现(?),最后是8个数字(\d{8})。
分枝条件
不幸的是,刚才那个表达式也能匹配010)12345678或(022-87654321这样的“不正确”的格式。要解决这个问题,我们需要用到分枝条件。正则表达式里的分枝条件指的是有几种规则,如果满足其中任意一种规则都应该当成匹配,具体方法是用|把不同的规则分隔开。听不明白?没关系,看例子:
0\d{2}-\d{8}|0\d{3}-\d{7}这个表达式能匹配两种以连字号分隔的电话号码:一种是三位区号,8位本地号(如010-
12345678),一种是4位区号,7位本地号(0376-2233445)。
(0\d{2})[- ]?\d{8}|0\d{2}[- ]?\d{8} 这个表达式匹配3位区号的电话号码,其中区号可以用小括号括起来,也可以不用,区号与本地号间可以用连字号或空格间隔,也可以没有间隔。你可以试试用分枝条件把这个表达式扩展成也支持4位区号的。
\d{5}-\d{4}|\d{5} 这个表达式用于匹配美国的邮政编码。美国邮编的规则是5位数字,或者用连字号间隔的9位数字。之所以要给出这个例子是因为它能说明一个问题:使用分枝条件时,要注意各个条件的顺序。如果你把它改成\d{5}|\d
{5}-\d{4} 的话,那么就只会匹配5位的邮编(以及9位邮编的前5位)。原因是匹配分枝条件时,将会从左到右地测试每个条件,如果满足了某个分枝的话,就不会去再管其它的条件了。
分组
我们已经提到了怎么重复单个字符(直接在字符后面加上限定符就行了);但如果想要重复多个字符又该怎么办?你可以用小括号来指定子表达式(也叫做分组),然后你就可以指定这个子表达式的重复次数了,你也可以对子表达式进行其它一些操作(后面会有介绍)。
(\d{1,3}.){3}\d{1,3} 是一个简单的IP地址匹配表达式。要理解这个表达式,请按下列顺序分析它: \d{1,3} 匹配 1到3位的数字, (\d{1,3}.){3} 匹配三位数字加上一个英文句号(这个整体也就是这个分组)重复3次,最后再加上一个一到三位的数字( \d{1,3} )。
不幸的是,它也将匹配 256.300.888.999 这种不可能存在的IP地址。如果能使用算术比较的话,或许能简单地解决这个问题,但是正则表达式中并不提供关于数学的任何功能,所以只能使用冗长的分组,选择,字符类来描述一个正确的IP地址: ((2[0-4]\d|25[0-5]|[01]?\d\d?).){3}(2[0-4]\d|25 [0-5]|[01]?\d\d?) 。
IP地址中每个数字都不能大于255. 经常有人问我, 01.02.03.04 这样前面带有0的数���, 是不是正确的IP地址呢? 答案是: 是的, IP 地址里的数字可以包含有前导 0 (leading zeroes).
理解这个表达式的关键是理解 2[0-4]\d|25[0-5]|[01]?\d\d? ,这里我就不细说了,你自己应该能分析得出来它的意义。
反义
有时需要查找不属于某个能简单定义的字符类的字符。比如想查找除了数字以外,其它任意字符都行的情况,这时需要用到反义:
表3.常用的反义代码
代码/语法 说明 \W 匹配任意不是字母,数字,下划线,汉字的字符 \S 匹配任意不是空白符的字符 \D 匹配任意非数字的字符 \B 匹配不是单词开头或结束的位置 [^x] 匹配除了x以外的任意字符 [^aeiou] 匹配除了aeiou这几个字母以外的任意字符
例子: \S+ 匹配不包含空白符的字符串。
<a[^>]+> 匹配用尖括号括起来的以a开头的字符串。
后向引用
使用小括号指定一个子表达式后,匹配这个子表达式的文本(也就是此分组捕获的内容)可以在表达式或其它程序中作进一步的处理。默认情况下,每个分组会自动拥有一个组号,规则是:从左向右,以分组的左括号为标志,第一个出现的分组的组号为1,第二个为2,以此类推。
其实,组号分配还不像我刚说得那么简单:
分组0对应整个正则表达式
实际上组号分配过程是要从左向右扫描两遍的:第一遍只给未命名组分配,第二遍只给命名组分配--因此所有命名组的组号都大于未命名的组号
你可以使用(?:exp)这样的语法来剥夺一个分组对组号分配的参与权.
后向引用用于重复搜索前面某个分组匹配的文本。例如,\1代表分组1匹配的文本。难以理解?请看示例:
\b(\w+)\b\s+\1\b可以用来匹配重复的单词,像go go ,或者kitty kitty 。这个表达式首先是一个单词,也就是单词开始处和结束处之间的多于一个的字母或数字(\b(\w+)\b),这个单词会被捕获到编号为1的分组中,然后是1个或几个空白符(\s+),最后是分组1中捕获的内容(也就是前面匹配的那个单词)(\1)。
你也可以自己指定子表达式的组名。要指定一个子表达式的组名,请使用这样的语法:(?<Word>\w+)(或者把尖括号换成’也行:(?’Word’\w+)),这样就把\w+的组名指定为Word了。要反向引用这个分组捕获的内容,你可以使用\k<Word>,所以上一个例子也可以写成这样:\b(?<Word>\w+)\b\s+\k<Word>\b。
使用小括号的时候,还有很多特定用途的语法。下面列出了最常用的一些:
表4.常用分组语法
分类 代码/语法 说明 捕获 (exp) 匹配exp,并捕获文本到自动命名的组里 (?<name>exp) 匹配exp,并捕获文本到名称为name的组里,也可以写成(?’name’exp) (?:exp) 匹配exp,不捕获匹配的文本,也不给此分组分配组号 零宽断言 (?=exp) 匹配exp前面的位置 (?<=exp) 匹配exp后面的位置 (?!exp) 匹配后面跟的不是exp的位置 (?<!exp) 匹配前面不是exp的位置 注释 (?#comment) 这种类型的分组不对正则表达式的处理产生任何影响,用于提供注释让人阅读
我们已经讨论了前两种语法。第三个(?:exp) 不会改变正则表达式的处理方式,只是这样的组匹配的内容不会像前两种那样被捕获到某个组里面,也不会拥有组号。“我为什么会想要这样做?”——好问题,你觉得为什么呢?
零宽断言
断言用来声明一个应该为真的事实。正则表达式中只有当断言为真时才会继续进行匹配。
接下来的四个用于查找在某些内容(但并不包括这些内容)之前或之后的东西,也就是说它们像\b,^,$那样用于指定一个位置,这个位置应该满足一定的条件(即断言),因此它们也被称为零宽断言。最好还是拿例子来说明吧:
(?=exp)也叫零宽度正预测先行断言,它断言自身出现的位置的后面能匹配表达式exp。比如\b\w+(?=ing\b),匹配以ing结尾的单词的前面部分(除了ing以外的部分),如查找I’m singing while you’re dancing.时,它会匹配sing和danc。
(?<=exp)也叫零宽度正回顾后发断言,它断言自身出现的位置的前面能匹配表达式exp。比如(?<=\bre)\w+\b会匹配以re开头的单词的后半部分(除了re以外的部分),例如在查找readinga book时,它匹配ading。
假如你想要给一个很长的数字中每三位间加一个逗号(当然是从右边加起了),你可以这样查找需要在前面和里面添加逗号的部分:((?<=\d)\d{3})+\b,用它对1234567890进行查找时结果是234567890。
下面这个例子同时使用了这两种断言:(?<=\s)\d+(?=\s)匹配以空白符间隔的数字(再次强调,不包括这些空白符)。
负向零宽断言
前面我们提到过怎么查找不是某个字符或不在某个字符类里的字符的方法(反义)。但是如果我们只是想要确保某个字符没有出现,但并不想去匹配它时怎么办?例如,如果我们想查找这样的单词–它里面出现了字母q,但是q后面跟的不是字母u,我们可以尝试这样:
\b\wq[^u]\w\b 匹配包含后面不是字母u的字母q的单词。但是如果多做测试(或者你思维足够敏锐,直接就观察出来了),你会发现,如果q出现在单词的结尾的话,像Iraq,Benq,这个表达式就会出错。这是因为[^u] 总要匹配一个字符,所以如果q是单词的最后一个字符的话,后面的[^u] 将会匹配q后面的单词分隔符(可能是空格,或者是句号或其它的什么),后面的\w\b 将会匹配下一个单词,于是\b\wq[^u]\w\b 就能匹配整个Iraq fighting 。 负向零宽断言能解决这样的问题,因为它只匹配一个位置,并不消费任何字符。现在,我们可以这样来解决这个问题: \b\wq(?!u)\w*\b 。
零宽度负预测先行断言 (?!exp) , 断言此位置的后面不能匹配表达式exp 。例如: \d{3}(?!\d) 匹配三位数字,而且这三位数字的后面不能是数字; \b((?!abc)\w)+\b 匹配不包含连续字符串abc的单词。
同理,我们可以用(?<!exp) , 零宽度负回顾后发断言来断言此位置的前面不能匹配表达式exp : (?<![a-z])\d{7} 匹配前面不是小写字母的七位数字。
一个更复杂的例子: (?<=<(\w+)>).(?=<\/\1>) 匹配不包含属性的简单HTML标签内里的内容。(?<=<(\w+)>) 指定了这样的前缀: 被尖括号括起来的单词(比如可能是<b>),然后是. (任意的字符串),最后是一个后缀
(?=<\/\1>) 。注意后缀里的\/ ,它用到了前面提过的字符转义; \1 则是一个反向引用,引用的正是捕获的第一组,前面的(\w+) 匹配的内容,这样如果前缀实际上是<b>的话,后缀就是</b>了。整个表达式匹配的是<b>和</b>之间的内容(再次提醒,不包括前缀和后缀本身)。
请详细分析表达式(?<=<(\w+)>).*(?=<\/\1>) ,这个表达式最能表现零宽断言的真正用途。
注释
小括号的另一种用途是通过语法(?#comment)来包含注释。例如:2[0-4]\d(?#200-249)|250-5|[01]?\d\d?(?#0-199)。
要包含注释的话,最好是启用“忽略模式里的空白符”选项,这样在编写表达式时能任意的添加空格,Tab,换行,而实际使用时这些都将被忽略。启用这个选项后,在#后面到这一行结束的所有文本都将被当成注释忽略掉。例如,我们可以前面的一个表达式写成这样:
(?<= #断言要匹配的文本的前缀
<(\w+)> #查找尖括号括起来的字母或数字(即HTML/XML标签)
) #前缀结束
.* #匹配任意文本
(?= #断言要匹配的文本的后缀
<\/\1> #查找尖括号括起来的内容:前面是一个”/”,后面是先前捕获的标签
) #后缀结束
贪婪与懒惰
当正则表达式中包含能接受重复的限定符时,通常的行为是(在使整个表达式能得到匹配的前提下)匹配尽可能多的字符。以这个表达式为例:a.*b,它将会匹配最长的以a开始,以b结束的字符串。如果用它来搜索aabab的话,它会匹配整个字符串aabab。这被称为贪婪匹配。
有时,我们更需要懒惰匹配,也就是匹配尽可能少的字符。前面给出的限定符都可以被转化为懒惰匹配模式,只要在它后面加上一个问号?。这样.*?就意味着匹配任意数量的重复,但是在能使整个匹配成功的前提下使用最少的重复。现在看看懒惰版的例子吧:
a.*?b匹配最短的,以a开始,以b结束的字符串。如果把它应用于aabab的话,它会匹配aab(第一到第三个字符)和ab(第四到第五个字符)。
为什么第一个匹配是aab(第一到第三个字符)而不是ab(第二到第三个字符)?简单地说,因为正则表达式有另一条规则,比懒惰/贪婪规则的优先级更高:最先开始的匹配拥有最高的优先权——The match that begins earliest wins。
表5.懒惰限定符
代码/语法 说明 *? 重复任意次,但尽可能少重复 +? 重复1次或更多次,但尽可能少重复 ?? 重复0次或1次,但尽可能少重复 {n,m}? 重复n到m次,但尽可能少重复 {n,}? 重复n次以上,但尽可能少重复
处理选项
上面介绍了几个选项如忽略大小写,处理多行等,这些选项能用来改变处理正则表达式的方式。下面是.Net中常用的正则表达式选项:
表6.常用的处理选项
名称 说明 IgnoreCase(忽略大小写) 匹配时不区分大小写。 Multiline(多行模式) 更改^和$的含义,使它们分别在任意一行的行首和行尾匹配,而不仅仅在整个字符串的开头和结尾匹配。(在此模式下,$的精确含意是:匹配\n之前的位置以及字符串结束前的位置.) Singleline(单行模式) 更改.的含义,使它与每一个字符匹配(包括换行符\n)。 IgnorePatternWhitespace(忽略空白) 忽略表达式中的非转义空白并启用由#标记的注释。 ExplicitCapture(显式捕获) 仅捕获已被显式命名的组。
在C#中,你可以使用Regex(String,RegexOptions)构造函数来设置正则表达式的处理选项。如:Regex regex = new Regex(@”\ba\w{6}\b”, RegexOptions.IgnoreCase);
一个经常被问到的问题是:是不是只能同时使用多行模式和单行模式中的一种?答案是:不是。这两个选项之间没有任何关系,除了它们的名字比较相似(以至于让人感到疑惑)以外。
平衡组/递归匹配
有时我们需要匹配像(100*(50+15))这样的可嵌套的层次性结构,这时简单地使用(.+)则只会匹配到最左边的左括号和最右边的右括号之间的内容(这里我们讨论的是贪婪模式,懒惰模式也有下面的问题)。假如原来的字符串里的左括号和右括号出现的次数不相等,比如(5/(3+2))),那我们的匹配结果里两者的个数也不会相等。有没有办法在这样的字符串里匹配到最长的,配对的括号之间的内容呢?
为了避免(和(把你的大脑彻底搞糊涂,我们还是用尖括号代替圆括号吧。现在我们的问题变成了如何把xx<aa<bbb><bbb>aa>yy这样的字符串里,最长的配对的尖括号内的内容捕获出来?这里需要用到以下的语法构造:
(?’group’)把捕获的内容命名为group,并压入堆栈(Stack)
(?’-group’)从堆栈上弹出最后压入堆栈的名为group的捕获内容,如果堆栈本来为空,则本分组的匹配失败
(?(group)yes|no)如果堆栈上存在以名为group的捕获内容的话,继续匹配yes部分的表达式,否则继续匹配no部分
(?!)零宽负向先行断言,由于没有后缀表达式,试图匹配总是失败
我们需要做的是每碰到了左括号,就在压入一个”Open”,每碰到一个右括号,就弹出一个,到了最后就看看堆栈是否为空--如果不为空那就证明左括号比右括号多,那匹配就应该失败。正则表达式引擎会进行回溯(放弃最前面或最后面的一些字符),尽量使整个表达式得到匹配。
< #最外层的左括号
[^<>]* #最外层的左括号后面的不是括号的内容 (
(
(?’Open'<) #碰到了左括号,在黑板上写一个”Open” [^<>]* #匹配左括号后面的不是括号的内容
)+
(
(?’-Open’>) #碰到了右括号,擦掉一个”Open” [^<>]* #匹配右括号后面不是括号的内容
)+
)*
(?(Open)(?!)) #在遇到最外层的右括号前面,判断黑板上还有没有没擦掉的”Open”;如果还有,则匹配失败
最外层的右括号
平衡组的一个最常见的应用就是匹配HTML,下面这个例子可以匹配嵌套的<div>标签: <div[^>]>[^<>](((?’Open'<div[^>]>)[^<>])+((?’Open'</div>)[^<>])+)(?(Open)(?!))</div> .
还有些什么东西没提到
上边已经描述了构造正则表达式的大量元素,但是还有很多没有提到的东西。下面是一些未提到的元素的列表,包含语法和简单的说明。你可以在网上找到更详细的参考资料来学习它们–当你需要用到它们的时候。如果你安装了MSDN Library,你也可以在里面找到.net下正则表达式详细的文档。这里的介绍很简略,如果你需要更详细的信息,而又没有在电脑上安装MSDN Library,可以查看关于正则表达式语言元素的MSDN在线文档。
表7.尚未详细讨论的语法
代码/语法 说明 \a 报警字符(打印它的效果是电脑嘀一声) \b 通常是单词分界位置,但如果在字符类里使用代表退格 \t 制表符,Tab \r 回车 \v 竖向制表符 \f 换页符 \n 换行符 \e Escape \0nn ASCII代码中八进制代码为nn的字符 \xnn ASCII代码中十六进制代码为nn的字符 \unnnn Unicode代码中十六进制代码为nnnn的字符 \cN ASCII控制字符。比如\cC代表Ctrl+C \A 字符串开头(类似^,但不受处理多行选项的影响) \Z 字符串结尾或行尾(不受处理多行选项的影响) \z 字符串结尾(类似$,但不受处理多行选项的影响) \G 当前搜索的开头 \p{name} Unicode中命名为name的字符类,例如\p{IsGreek} (?>exp) 贪婪子表达式 (?<x>-<y>exp) 平衡组 (?im-nsx:exp) 在子表达式exp中改变处理选项 (?im-nsx) 为表达式后面的部分改变处理选项 (?(exp)yes|no) 把exp当作零宽正向先行断言,如果在这个位置能匹配,使用yes作为此组的表达式;否则使用no (?(exp)yes) 同上,只是使用空表达式作为no (?(name)yes|no) 如果命名为name的组捕获到了内容,使用yes作为表达式;否则使用no (?(name)yes) 同上,只是使用空表达式作为no
网上的资源及本文参考文献
精通正则表达式(第3版)
微软的正则表达式教程
System.Text.RegularExpressions.Regex类(MSDN)
专业的正则表达式教学网站(英文)
关于.Net下的平衡组的详细讨论(英文)
相关资料
https://ift.tt/pwCDEG
from WordPress https://maphy.org/2806.html
0 notes
javascriptlastnews · 6 years
Text
Javascript ignorecase #News https://t.co/ZhDun4PMqQ
— JavaScript Facts (@mentallion) June 24, 2018
0 notes