一.概念
语法模式类似.
分隔符可以是任意非字母非数字,除反斜杠
如果分隔符 在表达式中使用,需要使用反斜线进行转义。
元字符
一个正则表达式基本组成
/原子和元字符/模式修正符 /代表定界符的一个
正则表达式的威力在于其能够在模式中包含选择和循环。它们通过使用元字符来编码在模式中,元字符不代表其自身,它们用一些特殊的方式来解析。
根据在方括号的内部还是外部分为两种。
1.方括号之外的元字符
元字符(符号) |
说明 |
\ |
一般用于转义字符 |
^ |
断言目标的开始位置(或在多行模式下是行首) |
$ |
目标的结束位置(活在多行模式下行尾) |
. |
匹配除换行符外任何字符(默认时) |
[,] |
开始,结束字符类定义 |
| |
开始一个可选分支 |
( ,) |
子组的开始,结尾标记 |
? |
作为量词,表示 0 次或 1 次匹配。位于量词后面用于改变量词的贪婪特性 |
* |
量词,0 次或多次匹配
|
+ |
量词,1 次或多次匹配
|
{ ,} |
自定义量词开始标记,结束标记
|
2.模式中方括号内的部分称为“字符类”
元字符 |
说明 |
\ |
转义字符 |
^ |
仅在作为第一个字符时,表明字符类取反 |
- |
标记字符范围 |
元字符用法说明举例
1.转义(反斜线)
\后紧跟着一个非字母数字字符,则取消该字符可能具有的任何特殊含义。此种适用于字符类之中或之外。
对于非数字字母的字符,总是需要其进行原文匹配时候在它前面加一个反斜线,来代表它代表自己。
匹配 “*” 时,由于其有特殊含义,所以用 “\*”取消掉了其特殊含义
匹配”.”用”\.”
匹配”\” 用”\\”
但要注意:
反斜线在单引号字符串和双引号字符串中都有特殊含义,因此要匹配一个反斜线,模式中必须写”\\\\”或’\\\’
2.反斜线第二种用途提供了一种对非打印字符进行可见编码的控制手段。除了二进制的
符号 |
说明 |
\a |
响铃字符(十六进制 07)
|
\cx |
"control-x",x 是任意字符
|
\e |
转义 (十六进制 1B)
|
\f |
换页 (十六进制 0C)
|
\n |
换行 (十六进制 0A)
|
\p{xx} (p |
一个符合 xx 属性的字符 |
\P{xx} (p |
一个不符合 xx 属性的字符 |
\r |
回车 (十六进制 0D)
|
\t |
水平制表符 (十六进制 09)
|
\xhh |
hh十六进制编码的字符 |
\ddd |
ddd八进制编码的字符,或者后向引用
|
\040 |
空格的另外一种用法
|
\40 |
当提供了少于40个子组时也认为是空格。
|
\7 |
始终是后向引用
|
\11 |
可能是后向引用,也可能是制表符 |
\011 |
总是一个制表符
|
\0113 |
一个制表符紧跟着一个3(因为每次最多只读取3个8进制位
|
\113 |
八进制113代表的字符
|
\377 |
8进制377是10进制255, 因此代表一个全1的字符
|
\81 |
一个后向引用或者一个二进制 0 紧跟着两个数字 8 和 1(因为8不是8进制有效数字)
|
3.反斜线第三种用法,描述特定的字符类
符号 |
说明 |
\d |
任意十进制数字 |
\D |
任意非十进制数字 |
\h |
任意水平空白字符 |
\H |
任意非水平空白字符 |
\s |
任意空白字符 |
\S |
任意空白字符 |
\v |
任意垂直空白字符(since PHP 5.2.4)
|
\V |
任意非垂直空白字符(since PHP 5.2.4)
|
\w |
任意单词字符
|
\W |
任意非单词字符
|
上面每一对转义序列都代表了完整字符集中两个不相交的部分, 任意字符一定会匹配其中一个,同时一定不会匹配另外一个。
第四种用法 简单的断言
\b |
单词边界 注意在字符类中是退格
|
\B |
非单词边界
|
\A |
目标的开始位置(独立于多行模式)
|
\Z |
目标的结束位置或结束处的换行符(独立于多行模式)
|
\z |
目标的结束位置(独立于多行模式)
|
\G |
在目标中首次匹配位置
|
\A,\Z,\z
因为他们永远匹配目标字符串的开始和结尾,而不会受模式修饰符的限制
\Z和 \z之间的不同在于当字符串结束字符时换行符时 \Z 会将其看做字符串结尾匹配, 而 \z 只匹配字符串结尾。
代码1
<span $p</span>='#\A[a-z]{3}#m'<span ; </span><span $str</span>='<span abc defg hijkl</span>'<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $all</span><span ); </span><span print_r</span>(<span $all</span>);
发现后面加不加模式修正符m
只匹配到
而代码
<span $p</span>='#^[a-z]{3}#m'<span ; </span><span $str</span>='<span abc defg hijkl</span>'<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $all</span><span ); </span><span print_r</span>(<span $all</span>);
不加m
加上之后匹配了
果真,
同理可比较
代码
<span <span $p</span>='#[a-z]\Z#'<span ; </span><span $str</span>="a\n"<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $all</span><span ); </span><span print_r</span>(<span $all</span>);</span>
模式修正为\E
当模式修正为
在指定了$offset 参数的 preg_match()() 调用中, 仅在当前匹配位置在匹配开始点的时候才是成功的
当 $offset 的值不为 0 的时候, 它与 \A 是不同的。
参见php手册
即把有特殊含义的字符放在\Q与\E之间
如代码4
<span $p</span>='#\w+\Q.$.\E$#'<span ; </span><span $str</span>="a.$."<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $all</span><span ); </span><span print_r</span>(<span $all</span>);
匹配到 a.$.
自 PHP 5.2.4 开始。。 比如, foot\Kbar 匹配”footbar”。 但是得到的匹配结果是 ”bar”。但是, \K 的使用不会干预到子组内的内容, 比如 (foot)\Kbar 匹配 ”footbar”,第一个子组内的结果仍然会是 ”foo”。译注: \K 放在子组和子组外面的效果是一样的。
\p{Lu}匹配大写字母
句点
在字符类外部
\C可以被用于匹配单字节, 也就是说在UTF-8模式下,句点可以匹配多字节字符
Character classes |
|
alnum |
字母和数字 |
alpha |
字母 |
ascii |
0 - 127的ascii字符 |
blank |
空格和水平制表符 |
cntrl |
控制字符 |
digit |
十进制数(same as \d) |
graph |
打印字符, 不包括空格 |
lower |
小写字母 |
|
打印字符,包含空格 |
punct |
打印字符, 不包括字母和数字 |
space |
空白字符 (比\s多垂直制表符) |
upper |
大写字母 |
word |
单词字符(same as \w) |
xdigit |
十六进制数字 |
比如'#[[:upper:]]#'匹配大写字母
'#[[:alpha:]]#' 匹配字母
竖线字符用于分离模式中的可选路径。 比如模式gilbert|Sullivan匹配 ”gilbert” 或者 ”sullivan”。 竖线可以在模式中出现任意多个,并且允许有空的可选路径(匹配空字符串)。 匹配的处理从左到右尝试每一个可选路径,并且使用第一个成功匹配的。 如果可选路径在子组(下面定义)中, 则”成功匹配”表示同时匹配了子模式中的分支以及主模式中的其他部分。
代码5
<span $p</span>='#p(hp|ython|erl)#'<span ; </span><span $str</span>="php python perl"<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $all</span><span ); </span><span print_r</span>(<span $all</span>);
子组通过圆括号分割界定,并且它们可以嵌套,主要有以下两种用法与功能
1.将可选分支局部化。比如
模式 p(hp|ython|erl) 匹配
2.将子组设定为捕获子组。
整个模式匹配后, 左括号从左至右出现的次序就是对应子组的下标(从 1 开始), 可以通过这些下标数字来获取捕获子模式匹配结果。
代码6
<span $p</span>='#(\d)#'<span ; </span><span $str</span>="abc123"<span ; </span><span $r</span>=<span preg_replace</span>(<span $p</span>,'<font color=red>\1</font>',<span $str</span><span ); </span><span echo</span> <span $r</span>;
在子组定义的左括号后面紧跟字符串 ”?:” 会使得该子组不被单独捕获, 并且不会对其后子组序号的计算产生影响
代码7:匹配数字 把数字改为红色的
<span $p</span>='#.*(?:\d).*([a-z])#U'<span ; </span><span $str</span>="3df5g"<span ; </span><span $r</span>=<span preg_replace</span>(<span $p</span>,'<font color=red>\1</font>',<span $str</span><span ); </span><span echo</span> <span $r</span>;
如果匹配数字的模式不加?:
那么
为了方便简写,如果需要在非捕获子组开始位置设置选项, ,比如:
上面两种写法实际上是相同的模式。因为可选分支会从左到右尝试每个分支, 并且选项没有在子模式结束前被重置, 并且由于选项的设置会穿透对后面的其他分支产生影响,因此, 上面的模式都会匹配 ”SUNDAY” 以及 ”Saturday”。
在 PHP 4.3.3 中,pattern) 的语法进行命名。 这个子模式将会在匹配结果中同时以其名称和顺序(数字下标)出现, PHP 5.2.2中又增加了两种味子组命名的语法: (?
代码如下8:
<span $p</span>="#.*(?<alpha>[a-z]{3})(?'digit'\d{3}).*#"<span ; </span><span $str</span>="abc123111def111g"<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $arr</span><span ); </span><span print_r</span>(<span $arr</span>);
结果:
有时需要多个匹配可以在一个正则表达式中选用子组。 为了让多个子组可以共用一个后向引用数字的问题, (?\语法允许复制数字。 考虑下面的正则表达式匹配Sunday:
(?:(Sat)ur|(Sun))day
这里当后向引用 1 空时Sun 存储在后向引用 2 中. 当后向引用 2 不存在的时候 Sat 存储在后向引用 1中。 使用 (?|修改模式来修复这个问题:
代码9:
<span $p</span>='#(?:(sat)ur|(sun))day#'<span ; </span><span $str</span>="sunday saturday"<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $arr</span><span ); </span><span print_r</span>(<span $arr</span>);
结果:
(?|(Sat)ur|(Sun))day
使用这个模式, Sun和Sat都会被存储到后向引用1中。
在看这个模式前先看以2个下代码
代码10-1
$p=<span '</span><span #(a|b)\d#</span><span '</span><span ; $str</span>=<span "</span><span b2a1</span><span "</span><span ; preg_match_all($p,$str,$arr); print_r($arr);</span>
结果是:Array
<em id="__mceDel">( [0] => Array ( [0] => b2 [1] => a1 ) [1] => Array ( [0] => b [1] => a ) )<br /><span <strong>代码10-2</strong></span><br /></em>
$p=<span '</span><span #((a)|b)\d#</span><span '</span><span ; $str</span>=<span "</span><span b2a1</span><span "</span><span ; preg_match_all($p,$str,$arr); print_r($arr);</span>
结果:
<strong>Array ( [0] => Array ( [0] => b2 [1] => a1 ) [1] => Array ( [0] => b [1] => a ) [2] => Array ( [0] => [1] => a )</strong> )<br /><strong>对10-2代码:<br /></strong>第一次完整匹配到的内容是b2,所以包括匹配内容b的括号即为其第一个子模式是即为b,第二个子模式由于(a)没有匹配,所以为空<br />第二次完整匹配到a1,其第一个子模式为a,第二次的由于((a)|b)是外层大括号里包含的<br /><strong>代码10-3:<br /></strong>
$p=<span '</span><span #((a)|(b))\d#</span><span '</span><span ; $str</span>=<span "</span><span b2a1</span><span "</span><span ; preg_match_all($p,$str,$arr); print_r($arr);</span>
<strong> 结果:<br /></strong>
Array ( [0] => Array ( [0] => b2 [1] => a1 ) [1] => Array ( [0] => b [1] => a ) [2] => Array ( [0] => [1] => a ) [3] => Array ( [0] => b [1] => ) )
代码10-4:
$p=<span '</span><span #(?:(a)|(b))\d#</span><span '</span><span ; $str</span>=<span "</span><span b2a1</span><span "</span><span ; preg_match_all($p,$str,$arr); print_r($arr);</span>
结果:<br />Array ( [0] => Array ( [0] => b2 [1] => a1 ) [1] => Array ( [0] => [1] => a ) [2] => Array ( [0] => b [1] => ) )
<strong> </strong>
代码10:
<span $p</span>='#(?|(sat)ur|(sun))day#'<span ; </span><span $str</span>="sunday saturday"<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $arr</span><span ); </span><span print_r</span>(<span $arr</span>);
结果
如果紧跟反斜线的数字小于 10, 它总是一个后向引用。模式中的捕获数要大于等于后向引用的个数
后向引用会直接匹配被引用捕获组在目标字符串中实际捕获到的内容, 而不是匹配子组模式的内容
(sens|respons)e and \1ibility将会匹配
<span $p</span>='#(sens|respons)e and \1ibility#'<span ; </span><span $str</span>="sense and sensibility response and responsibility sense and responsibility"<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $arr</span><span ); </span><span print_r</span>(<span $arr</span>);
结果
ab(?i)c匹配abC
如果在后向引用时被强制进行了大小写敏感匹配
((?i)abc)\s+\1
匹配
ABC ABC
AbC AbC
只要两个一样不分大小写
但不匹配
这里其实要考虑的是后向引用期望得到的内容是和那个被引用的捕获子组得到的内容是完全一致的
代码12:
<span $p</span>='#((?i)abc)\s+\1#'<span ; </span><span $str</span>="abc abc |ABC ABC |AbC AbC |abc Abc "<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $arr</span><span ); </span><span print_r</span>(<span $arr</span>);
结果
先看以下代码13
<span $p</span>='#(a|(bc))#'<span ; </span><span $str</span>="abc "<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $arr</span><span ); </span><span print_r</span>(<span $arr</span>);
完整匹配了2次
[0][0]是第一次完整的匹配
[1][0]是第一次匹配的第一个子模式
[2][0]是第一次匹配的第二个子模式
[0][1]第二次完整匹配
[1][1]第二次匹配的第一个子模式
[2][1]是第二次匹配的第二个子模式
从上面可以发现对于模式
(a|(bc))
最外面的括号是第一个匹配子模式
里面的括号里的是第二个子模式
所以对于以下代码14:
<span $p</span>='#(a|(bc))\2#'<span ; </span><span $str</span>="aabcbc"<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $arr</span><span ); </span><span print_r</span>(<span $arr</span>);
结果
当第一匹配
就无从
所以第一次完整匹配中必须得有让第二个子模式存在的机会即里面的括号里的内容必须被匹配到,所以必须得有
因为可能会有多达 99 个后向引用, 所有紧跟反斜线后的数字都可能是一个潜在的后向引用计数。 如果模式在后向引用之后紧接着还是一个数值字符, 那么必须使用一些分隔符用于终结后向引用语法。
以下代码15为例:
<span $p</span>='#([a-z]{3})\1 5#x'<span ; </span><span $str</span>="aaaaaa5"<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $arr</span><span ); </span><span print_r</span>(<span $arr</span>);
模式后向引用\1
我们空下一格,然后在模式修正里忽略模式里的空格就能成功匹配
(a\1) 就不会得到任何匹配
而这种引用可以用于内部的子模式重复
(a|b\1)会匹配 ”a”但不会匹配b( 因为子组内部有一个可选路径,可选路径中有一条路能够完成匹配,在匹配完成后, 后向引用就能够引用到内容了)。
代码16:
<span $p</span>='#(a|b\1)+#'<span ; </span><span $str</span>="abba"<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $arr</span><span ); </span><span print_r</span>(<span $arr</span>);
结果
在每次子模式的迭代过程中, 后向引用匹配上一次迭代时这个子组匹配到的字符串。为了做这种工作, 模式必须满足这样一个条件,模式在第一次迭代的时候, 必须能够保证不需要匹配后向引用。 这种条件可以像上面的例子用可选路径来实现,也可以通过使用最小值为 0 的量词修饰后向引用的方式来完成。
在 PHP 5.2.2之后, g转义序列可以用于子模式的绝对和相对引用。 这个转义序列必须紧跟一个无符号数字或一个负数, 可以选择性的使用括号对数字进行包裹。 序列\1, \g1,\g{1} 之间是同义词关系。 这种用法可以消除使用反斜线紧跟数值描述反向引用时候产生的歧义。 这种转义序列有利于区分后向引用和八进制数字字符, 也使得后向引用后面紧跟一个原文匹配数字变的更明了,比如 \g{2}1。
代码17:
<span $p</span>='#([a-z]{2})\g{1}5#'<span ; </span><span $str</span>="abab5"<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $arr</span><span ); </span><span print_r</span>(<span $arr</span>);
可与代码15对比
\g 转义序列紧跟一个负数代表一个相对的后向引用。比如: (foo)(bar)\g{-1} 可以匹配字符串 ”foobarbar”(foo)(bar)\g{-2} 可以匹配 ”foobarfoo”。 这在长的模式中作为一个可选方案, 用来保持对之前一个特定子组的引用的子组序号的追踪。
代码18
<span $p</span>='#(foo)(bar)\g{-1}#'<span ; </span><span $p1</span>='#(foo)(bar)\g{-2}#'<span ; </span><span $str</span>="foobarbar"<span ; </span><span $str1</span>="foobarfoo"<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $arr</span><span ); </span><span preg_match_all</span>(<span $p1</span>,<span $str1</span>,<span $arr1</span><span ); </span><span print_r</span>(<span $arr</span><span ); </span><span print_r</span>(<span $arr1</span>);
结果:
后向引用也支持使用子组名称的语法方式描述, 比如 (?P=name) 或者 PHP 5.2.2 开始可以实用\k
代码19:
<span $p</span>="#(?<span 'alpha'</span>[a-z]{2})(?<digt>[0-9]{3})\k<digt>(?<span P=alpha</span>)#"<span ; </span><span $str</span>="aa123123aa"<span ; </span><span preg_match_all</span>(<span $p</span>,<span $str</span>,<span $arr</span><span ); </span><span print_r</span>(<span $arr</span>);
结果:
可与代码8比较着看
注意标红的
Alpha
P

PHP는 현대 웹 개발, 특히 컨텐츠 관리 및 전자 상거래 플랫폼에서 중요합니다. 1) PHP는 Laravel 및 Symfony와 같은 풍부한 생태계와 강력한 프레임 워크 지원을 가지고 있습니다. 2) Opcache 및 Nginx를 통해 성능 최적화를 달성 할 수 있습니다. 3) PHP8.0은 성능을 향상시키기 위해 JIT 컴파일러를 소개합니다. 4) 클라우드 네이티브 애플리케이션은 Docker 및 Kubernetes를 통해 배포되어 유연성과 확장 성을 향상시킵니다.

PHP는 특히 빠른 개발 및 동적 컨텐츠를 처리하는 데 웹 개발에 적합하지만 데이터 과학 및 엔터프라이즈 수준의 애플리케이션에는 적합하지 않습니다. Python과 비교할 때 PHP는 웹 개발에 더 많은 장점이 있지만 데이터 과학 분야에서는 Python만큼 좋지 않습니다. Java와 비교할 때 PHP는 엔터프라이즈 레벨 애플리케이션에서 더 나빠지지만 웹 개발에서는 더 유연합니다. JavaScript와 비교할 때 PHP는 백엔드 개발에서 더 간결하지만 프론트 엔드 개발에서는 JavaScript만큼 좋지 않습니다.

PHP와 Python은 각각 고유 한 장점이 있으며 다양한 시나리오에 적합합니다. 1.PHP는 웹 개발에 적합하며 내장 웹 서버 및 풍부한 기능 라이브러리를 제공합니다. 2. Python은 간결한 구문과 강력한 표준 라이브러리가있는 데이터 과학 및 기계 학습에 적합합니다. 선택할 때 프로젝트 요구 사항에 따라 결정해야합니다.

PHP는 서버 측에서 널리 사용되는 스크립팅 언어이며 특히 웹 개발에 적합합니다. 1.PHP는 HTML을 포함하고 HTTP 요청 및 응답을 처리 할 수 있으며 다양한 데이터베이스를 지원할 수 있습니다. 2.PHP는 강력한 커뮤니티 지원 및 오픈 소스 리소스를 통해 동적 웹 컨텐츠, 프로세스 양식 데이터, 액세스 데이터베이스 등을 생성하는 데 사용됩니다. 3. PHP는 해석 된 언어이며, 실행 프로세스에는 어휘 분석, 문법 분석, 편집 및 실행이 포함됩니다. 4. PHP는 사용자 등록 시스템과 같은 고급 응용 프로그램을 위해 MySQL과 결합 할 수 있습니다. 5. PHP를 디버깅 할 때 error_reporting () 및 var_dump ()와 같은 함수를 사용할 수 있습니다. 6. 캐싱 메커니즘을 사용하여 PHP 코드를 최적화하고 데이터베이스 쿼리를 최적화하며 내장 기능을 사용하십시오. 7

PHP가 많은 웹 사이트에서 선호되는 기술 스택 인 이유에는 사용 편의성, 강력한 커뮤니티 지원 및 광범위한 사용이 포함됩니다. 1) 배우고 사용하기 쉽고 초보자에게 적합합니다. 2) 거대한 개발자 커뮤니티와 풍부한 자원이 있습니다. 3) WordPress, Drupal 및 기타 플랫폼에서 널리 사용됩니다. 4) 웹 서버와 밀접하게 통합하여 개발 배포를 단순화합니다.

PHP는 현대적인 프로그래밍, 특히 웹 개발 분야에서 강력하고 널리 사용되는 도구로 남아 있습니다. 1) PHP는 사용하기 쉽고 데이터베이스와 완벽하게 통합되며 많은 개발자에게 가장 먼저 선택됩니다. 2) 동적 컨텐츠 생성 및 객체 지향 프로그래밍을 지원하여 웹 사이트를 신속하게 작성하고 유지 관리하는 데 적합합니다. 3) 데이터베이스 쿼리를 캐싱하고 최적화함으로써 PHP의 성능을 향상시킬 수 있으며, 광범위한 커뮤니티와 풍부한 생태계는 오늘날의 기술 스택에 여전히 중요합니다.

PHP에서는 약한 참조가 약한 회의 클래스를 통해 구현되며 쓰레기 수집가가 물체를 되 찾는 것을 방해하지 않습니다. 약한 참조는 캐싱 시스템 및 이벤트 리스너와 같은 시나리오에 적합합니다. 물체의 생존을 보장 할 수 없으며 쓰레기 수집이 지연 될 수 있음에 주목해야합니다.

\ _ \ _ 호출 메소드를 사용하면 객체를 함수처럼 호출 할 수 있습니다. 1. 객체를 호출 할 수 있도록 메소드를 호출하는 \ _ \ _ 정의하십시오. 2. $ obj (...) 구문을 사용할 때 PHP는 \ _ \ _ invoke 메소드를 실행합니다. 3. 로깅 및 계산기, 코드 유연성 및 가독성 향상과 같은 시나리오에 적합합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기
