From 72496cb355c02bbb63e2de7cb7ec4255557f9a3c Mon Sep 17 00:00:00 2001 From: Lin Yang <1074504492@qq.com> Date: Thu, 9 May 2019 17:12:55 +0800 Subject: [PATCH] fix doc error --- Day01-15/Day02/语言元素.md | 16 ++++++++-------- Day01-15/Day03/res/formula_1.png | Bin 0 -> 1940 bytes Day01-15/Day03/分支结构.md | 10 +++++----- Day01-15/Day04/res/formula_1.png | Bin 0 -> 487 bytes Day01-15/Day04/循环结构.md | 4 ++-- Day01-15/Day06/res/formula_1.png | Bin 0 -> 618 bytes Day01-15/Day06/res/formula_2.png | Bin 0 -> 1270 bytes Day01-15/Day06/函数和模块的使用.md | 8 ++++---- Day01-15/Day07/res/formula_1.png | Bin 0 -> 816 bytes Day01-15/Day07/res/formula_2.png | Bin 0 -> 365 bytes Day01-15/Day07/res/formula_3.png | Bin 0 -> 311 bytes Day01-15/Day07/res/formula_4.png | Bin 0 -> 798 bytes .../Day07/字符串和常用数据结构.md | 14 +++++++------- Day01-15/Day08/面向对象编程基础.md | 8 ++++---- Day01-15/Day09/面向对象进阶.md | 2 +- .../Day10/图形用户界面和游戏开发.md | 4 ++-- Day01-15/Day11/文件和异常.md | 16 ++++++++-------- Day01-15/Day12/字符串和正则表达式.md | 12 ++++++------ Day01-15/Day13/进程和线程.md | 2 +- Day01-15/Day14-A/网络编程入门.md | 8 ++++---- 20 files changed, 52 insertions(+), 52 deletions(-) create mode 100644 Day01-15/Day03/res/formula_1.png create mode 100644 Day01-15/Day04/res/formula_1.png create mode 100644 Day01-15/Day06/res/formula_1.png create mode 100644 Day01-15/Day06/res/formula_2.png create mode 100644 Day01-15/Day07/res/formula_1.png create mode 100644 Day01-15/Day07/res/formula_2.png create mode 100644 Day01-15/Day07/res/formula_3.png create mode 100644 Day01-15/Day07/res/formula_4.png diff --git a/Day01-15/Day02/语言元素.md b/Day01-15/Day02/语言元素.md index 4a0937c..2fdbf94 100644 --- a/Day01-15/Day02/语言元素.md +++ b/Day01-15/Day02/语言元素.md @@ -99,11 +99,11 @@ print(type(e)) 在对变量类型进行转换时可以使用Python的内置函数(准确的说下面列出的并不是真正意义上的函数,而是后面我们要讲到的创建对象的构造方法)。 -- int():将一个数值或字符串转换成整数,可以指定进制。 -- float():将一个字符串转换成浮点数。 -- str():将指定的对象转换成字符串形式,可以指定编码。 -- chr():将整数转换成该编码对应的字符串(一个字符)。 -- ord():将字符串(一个字符)转换成对应的编码(整数)。 +- `int()`:将一个数值或字符串转换成整数,可以指定进制。 +- `float()`:将一个字符串转换成浮点数。 +- `str()`:将指定的对象转换成字符串形式,可以指定编码。 +- `chr()`:将整数转换成该编码对应的字符串(一个字符)。 +- `ord()`:将字符串(一个字符)转换成对应的编码(整数)。 ### 运算符 @@ -118,15 +118,15 @@ Python支持多种运算符,下表大致按照优先级从高到低的顺序 | `+` `-` | 加,减 | | `>>` `<<` | 右移,左移 | | `&` | 按位与 | -| `^` `|` | 按位异或,按位或 | +| `^` `\|` | 按位异或,按位或 | | `<=` `<` `>` `>=` | 小于等于,小于,大于,大于等于 | | `==` `!=` | 等于,不等于 | | `is` `is not` | 身份运算符 | | `in` `not in` | 成员运算符 | | `not` `or` `and` | 逻辑运算符 | -| `=` `+=` `-=` `*=` `/=` `%=` `//=` `**=` `&=` `|=` `^=` `>>=` `<<=` | (复合)赋值运算符 | +| `=` `+=` `-=` `*=` `/=` `%=` `//=` `**=` `&=` `\|=` `^=` `>>=` `<<=` | (复合)赋值运算符 | ->**说明:**在实际开发中,如果搞不清楚优先级可以使用括号来确保运算的执行顺序。 +>**说明:** 在实际开发中,如果搞不清楚优先级可以使用括号来确保运算的执行顺序。 下面的例子演示了运算符的使用。 diff --git a/Day01-15/Day03/res/formula_1.png b/Day01-15/Day03/res/formula_1.png new file mode 100644 index 0000000000000000000000000000000000000000..5a0a7e2a7b949b466497ed9a08462d54f39756e9 GIT binary patch literal 1940 zcmb7F_d6R38%;`UiygIMi%N}KN^6tGst7?#UE1p9qKMinHqn7=M6DXRdhOW?wbD?k zL8+QGLY0sjQG%jA{S&_TdCq&@=Q+>$;XS{cR20&Thf|Cb008h?~)y zgWc)$jIN??+TS=m{eAwwW2Q!^JM-`d*&)#YzPylj`?=I1xX0EX)v`v!d9Q5aGm!&h z?i2_B@b>-&Fh_+~900hmY5_O44+C!8`4UgR#I8kLdC~mi)G+chG`?iuRm<4$O^6tQ z9j1D3T>WL7zBseqoHn4>+$ntN*VS?*!1O_#cDH+ zKV_qp#Wj!CovhK#t~(PgbT`Wd55_UF&Oz7tapN_aDCCcZ$eK=7drWRti?x;5Tn7E( zObd1fL|wn1K0-A2VlFw%c_&{vFzkt@bevc8H=B)dl0>*vb}TFQqy<4EnzyFH!TK*o zU(Lby^6~o&Qm#s$NSlG3McjTLy{h16V}awvc)!V>S9Ar)`c+XWuF9W3{U{ETZu{3ifhF27 zrH6(}y0N_3-o3`Q#+N-cT2f1Sqm9U1oK(h;>hvvo{|8cT@jXIjQQM?Cv>{)L)m@`= zW7%WYcIa7nml98m1#<(42G3-LECPTeaRJ63BFMo9m z0SY$riKsg)Y?}JJNo+O5GOo6sI#1`2a(~8r%oKjXP+QBFG3agvXVKtBm_EkNFUWJzsZ)Bb4n= zuf&es7%SHr#Xcl)rP+9JZ&P8B)K-F_bcJ2k0rRkE|JM%23Hx05#?whvpnf01x} z`fq`G@Nvr&`PHo@8>EDXCg6LM2S*F*-V|1)* zIg{Z|f~HV16ltR%t}6*8~z zSWi%|zwc4j17SSrAvN&NUZGqgg5JvZJ2UOPDIlzsf&NL zW~T^IQc%&IWVO4Jp%ThUBF&uM?O#j%)~lL5XH~w59&kZ@$=R@Ffm9JFH-x%)_F}aV zg^lV8d?Xpq6V#b~a+l=v^tt-y3IQ|#>dV^LuPZX7{8W^>hflaI%vef^xEbNaC!d@=(z?)&Dhb`uJeAnKbnsyxl0mp6nX$=DS}jPMPEK~@Y=(w8)swbEcKG$=+KwD(CC z`HLxwIYHIbKC6OAw$YxS;|W$`*?FypkLildTO5PnPt?WusaE=FUmFp->W6zX^g-sB z$_AkuI-?0pD*r*~YZr8N(!+y%3Qc3T-FkYZJPlzQK!XB*Y*|V|W44Go)Q3#7PJ&)9 zgX`7ks_63oEF>u1d{vPBUdZijp17|OmyF-dz4I!5 zz6e$iWdwllxRr%hY+^hO7YCC4k{H8U%2mhMLg!*GkNWF~%<|SHWS?yX6cSfD0frkm z1`ia0;n{3hW14QpF))Trt-~(GFunWJ%$77A9H}=i-Ibv0TGFG&)R~d!B8~XVm38z( zoZE7obBn&@0=nI8$O?tENdlky-*Kp=@K)~Nh>|ci zjNIjLZzcY~W-+9}s@$5m*=PCu%wTpMiN;jH>$W4KxLlA2?E)D14c4nh1)}\\x+2&\text{(-1}\leq\text{x}\leq\text{1)}\\5x+3&\text {(x<-1)}\end{cases}$$ +![](./res/formula_1.png) ```Python """ @@ -79,7 +79,7 @@ else: print('f(%.2f) = %.2f' % (x, y)) ``` -> **说明:**大家可以自己感受一下这两种写法到底是哪一种更好。在之前我们提到的Python之禅中有这么一句话“Flat is better than nested.”,之所以提出这个观点是因为嵌套结构的嵌套层次多了之后会严重的影响代码的可读性,如果可以使用扁平化的结构就不要去用嵌套,因此之前的写法是更好的做法。 +> **说明:** 大家可以自己感受一下这两种写法到底是哪一种更好。在之前我们提到的Python之禅中有这么一句话“Flat is better than nested.”,之所以提出这个观点是因为嵌套结构的嵌套层次多了之后会严重的影响代码的可读性,如果可以使用扁平化的结构就不要去用嵌套,因此之前的写法是更好的做法。 ### 练习 @@ -130,7 +130,7 @@ else: result = '讲冷笑话' print(result) ``` -> **说明:**上面的代码中使用了random模块的randint函数生成指定范围的随机数来模拟掷骰子。 +> **说明:** 上面的代码中使用了random模块的randint函数生成指定范围的随机数来模拟掷骰子。 #### 练习3:百分制成绩转等级制 @@ -184,7 +184,7 @@ if a + b > c and a + c > b and b + c > a: else: print('不能构成三角形') ``` -> **说明:**上面的代码中使用了`math`模块的`sqrt`函数来计算平方根。用边长计算三角形面积的公式叫做[海伦公式](https://zh.wikipedia.org/zh-hans/海伦公式)。 +> **说明:** 上面的代码中使用了`math`模块的`sqrt`函数来计算平方根。用边长计算三角形面积的公式叫做[海伦公式](https://zh.wikipedia.org/zh-hans/海伦公式)。 #### 练习5:个人所得税计算器。 @@ -227,4 +227,4 @@ tax = abs(diff * rate - deduction) print('个人所得税: ¥%.2f元' % tax) print('实际到手收入: ¥%.2f元' % (diff + 3500 - tax)) ``` ->**说明:**上面的代码中使用了Python内置的`abs()`函数取绝对值来处理`-0`的问题。 +>**说明:** 上面的代码中使用了Python内置的`abs()`函数取绝对值来处理`-0`的问题。 diff --git a/Day01-15/Day04/res/formula_1.png b/Day01-15/Day04/res/formula_1.png new file mode 100644 index 0000000000000000000000000000000000000000..c21c2ae5029e30f7b6ef27eff0637e7934f1ae9a GIT binary patch literal 487 zcmeAS@N?(olHy`uVBq!ia0vp^RzNJl!VDxMKYmsNQU(D&A+G=b{|7RO2l{sxR0CD> zmjw9*GrT{$`)>fl{0W9+AZi417mGm~pB$pELslqm!qLV~B=m zZJ@39VF!u2TeJF)^-^Djm6X5G#ZuI%;-j+%cA>$d#mP1Ew{fRRF^h!sn@ivR_9s_?}r{){_e5o zFYS3+u^A7eGm=A9FIx&2w}gp{Ykh4!?O@;if$Q$~j8om+4vGSc*gsFZck)w;mCc^Y z*WRxE(+>JRIsEMSn->aQi_-6%3r)@bomP6!Q*6`T>Jp2d$u~CcaSHmh_w~jjEUL%% qZvQ{eCe~k`ty+cm?;4Xo;eVLC;uGgz`jxX26jz?EelF{r5}E+rWV}-V literal 0 HcmV?d00001 diff --git a/Day01-15/Day04/循环结构.md b/Day01-15/Day04/循环结构.md index c3adf99..f51bb3f 100644 --- a/Day01-15/Day04/循环结构.md +++ b/Day01-15/Day04/循环结构.md @@ -6,7 +6,7 @@ ### for-in循环 -如果明确的知道循环执行的次数或者是要对一个容器进行迭代(后面会讲到),那么我们推荐使用`for-in`循环,例如下面代码中计算$\sum_{n=1}^{100}n$。 +如果明确的知道循环执行的次数或者是要对一个容器进行迭代(后面会讲到),那么我们推荐使用`for-in`循环,例如下面代码中计算![](./res/formula_1.png)。 ```Python """ @@ -94,7 +94,7 @@ if counter > 7: print('你的智商余额明显不足') ``` -> **说明:**上面的代码中使用了`break`关键字来提前终止循环,需要注意的是`break`只能终止它所在的那个循环,这一点在使用嵌套的循环结构(下面会讲到)需要引起注意。除了`break`之外,还有另一个关键字是`continue`,它可以用来放弃本次循环后续的代码直接让循环进入下一轮。 +> **说明:** 上面的代码中使用了`break`关键字来提前终止循环,需要注意的是`break`只能终止它所在的那个循环,这一点在使用嵌套的循环结构(下面会讲到)需要引起注意。除了`break`之外,还有另一个关键字是`continue`,它可以用来放弃本次循环后续的代码直接让循环进入下一轮。 和分支结构一样,循环结构也是可以嵌套的,也就是说在循环中还可以构造循环结构。下面的例子演示了如何通过嵌套的循环来输出一个九九乘法表。 diff --git a/Day01-15/Day06/res/formula_1.png b/Day01-15/Day06/res/formula_1.png new file mode 100644 index 0000000000000000000000000000000000000000..b9a84ed9779602214d9ff8cefa974b1ee8243c0e GIT binary patch literal 618 zcmeAS@N?(olHy`uVBq!ia0vp^D}h*mg&9cBw{uzuqznRlLR|m<{|{sm5A^RYs0OO$ zFA4GsW(Y~^bXl$R-sr5r%-wg({?_Z40Hrt!JR*x382FBWFymBhK4}I9#-pAtjv*F; zTPN-IJ{%x&Y=6w;sMpO=vPT@bUM*rXN*kmO2I!sP(qq-q)y&UlTB{%A zzV2b@8Kd20FV7U3hD~zsyJT;4uy*n5dAs!X$}5!diN)^bR$sWQFK@q@=wzcUG9O#- zKmHN%1)*(=eFv?fLW9GT6WY%Y>%0}z02q6qx@16zQ*Rh zZQq`-Ik^?vc?COsTV>eJ^sD6jko8wY0mrAY=4D+ YFfz7Bav9{kSOrQhp00i_>zopr0FtZpiU0rr literal 0 HcmV?d00001 diff --git a/Day01-15/Day06/res/formula_2.png b/Day01-15/Day06/res/formula_2.png new file mode 100644 index 0000000000000000000000000000000000000000..692fb08165873f29c502ad7a735ee1d50cbaf6d4 GIT binary patch literal 1270 zcmVrg%|QjlfgqxLX;@?<1X;6@kbr0oIYda( z5QN}@(-(stWar|=)2?0u3id%o2xuz?L_Caw;B99mE>S|(SKVDTy_4=4dba1oP{00v z_1~Yas$W$=KAFEm{M2oC&CNHiK(ziPgMB}TAG`vC<_l&00o2+a*4=#L3PfK!4w&me zd!@jj`9cM+0sa#}Bj2zh(aud&-3vgy$e{UR1#Orbcg0M;VFjX%mBxy1_JDGML1n1b zZQN|hPG)Oi`dhcs;gZaRjPI}(ppPD{W9B3dIHQ5%Agnc5qsP68au;v8z^a`I)`Cpe z{SGS;$C~l4-;WruRK5swue9|NFr+|N1_ll7YAxZ`9(loe182={p6rLjJ%QOP9{pR- z#Gumd?(STupW5=Ude4vT)~)A&4@76)Md=~}+$bo8F0j-Dj2B}jls>w4HP)9lftIvC ziAE6a?x_x|evc_E6_bL+Ft2WN&&*3IuCZTY-T54Fr2S<~H=+B$qD@nWj)p6J`)a3F z$in)0P^AD=C9SjW_fue*4^V5uxGM<#)xVHy8D(cVO_#IGkckvjXs5E7Oo4|DHZZl3 z9c?U6m_ozblR~)WL^KEQBvSbLC`~=on*&70k5Lu|j5)ezh;_N7xg0XF)KM~c)L$`y{jv$PsydhGU7M2g8J#WMK z+m^n4w1+s>!G(i~6f81DLbA((FqEg6k5~)h%+YB5)x(2S(f>-KGlqm~0n0v9kP}hq z$~YuycVmj`U6gww1#thoOTksQV$M{G*y z3$M5|{We!S=f%F1X2jX^V>Dzf09cx4?*$e6)K@%8A}P0csL+MeqBxT?68+I^Mw^q*h50i2*uK4X%w7-H~? z5(S^X$CG}g*IcFUQ9f2Z3!C20swb6YezX?Me}OJd@);w&VH-i{7bxAPE&YRKT(h*6 zil*aFaApSN);2UB#vL)ioaOi#vj-GGa8jV6>)eQCvu8B=R~GFl_c8sp_zy`jUjGNC zjoMDQ%pspKDG*#0s0oOUMRB3jdI(ple8wc1Vh905O+a+CJ#nXvQ;^S?B$I^H1!@BF zFlIVu8MliwBD#FWB$*`SfKAi{P6Tv7UOrbe}40xHtXAT4V z5ND5i#w4jEgp0*b+KbW||A1U6kGdO3Hmh`hnvC6|*8781; g!~bS{Wf_b3f61*i1M?){u>b%707*qoM6N<$f+*57b^rhX literal 0 HcmV?d00001 diff --git a/Day01-15/Day06/函数和模块的使用.md b/Day01-15/Day06/函数和模块的使用.md index 202b9e7..0457405 100644 --- a/Day01-15/Day06/函数和模块的使用.md +++ b/Day01-15/Day06/函数和模块的使用.md @@ -2,11 +2,11 @@ 在讲解本章节的内容之前,我们先来研究一道数学题,请说出下面的方程有多少组正整数解。 -$$x_1 + x_2 + x_3 + x_4 = 8$$ +![](./res/formula_1.png) 事实上,上面的问题等同于将8个苹果分成四组每组至少一个苹果有多少种方案。想到这一点问题的答案就呼之欲出了。 -$$C_M^N =\frac{M!}{N!(M-N)!}, \text{(M=7, N=3)} $$ +![](./res/formula_2.png) 可以用Python的程序来计算出这个值,代码如下所示。 @@ -59,7 +59,7 @@ n = int(input('n = ')) print(factorial(m) // factorial(n) // factorial(m - n)) ``` -> **说明:**Python的math模块中其实已经有一个factorial函数了,事实上要计算阶乘可以直接使用这个现成的函数而不用自己定义。下面例子中的某些函数其实Python中也是内置了,我们这里是为了讲解函数的定义和使用才把它们又实现了一遍,实际开发中不建议做这种低级的重复性的工作。 +> **说明:** Python的math模块中其实已经有一个factorial函数了,事实上要计算阶乘可以直接使用这个现成的函数而不用自己定义。下面例子中的某些函数其实Python中也是内置了,我们这里是为了讲解函数的定义和使用才把它们又实现了一遍,实际开发中不建议做这种低级的重复性的工作。 ### 函数的参数 @@ -337,7 +337,7 @@ if __name__ == '__main__': 在实际开发中,我们应该尽量减少对全局变量的使用,因为全局变量的作用域和影响过于广泛,可能会发生意料之外的修改和使用,除此之外全局变量比局部变量拥有更长的生命周期,可能导致对象占用的内存长时间无法被[垃圾回收](https://zh.wikipedia.org/wiki/%E5%9E%83%E5%9C%BE%E5%9B%9E%E6%94%B6_(%E8%A8%88%E7%AE%97%E6%A9%9F%E7%A7%91%E5%AD%B8))。事实上,减少对全局变量的使用,也是降低代码之间耦合度的一个重要举措,同时也是对[迪米特法则](https://zh.wikipedia.org/zh-hans/%E5%BE%97%E5%A2%A8%E5%BF%92%E8%80%B3%E5%AE%9A%E5%BE%8B)的践行。减少全局变量的使用就意味着我们应该尽量让变量的作用域在函数的内部,但是如果我们希望将一个局部变量的生命周期延长,使其在函数调用结束后依然可以访问,这时候就需要使用[闭包](https://zh.wikipedia.org/wiki/%E9%97%AD%E5%8C%85_(%E8%AE%A1%E7%AE%97%E6%9C%BA%E7%A7%91%E5%AD%A6)),这个我们在后续的内容中进行讲解。 -> **说明**:很多人经常会将“闭包”一词和[“匿名函数”](https://zh.wikipedia.org/wiki/%E5%8C%BF%E5%90%8D%E5%87%BD%E6%95%B0)混为一谈,但实际上它们是不同的概念,如果想提前了解这个概念,推荐看看[维基百科](https://zh.wikipedia.org/wiki/)或者[知乎](https://www.zhihu.com/)上对这个概念的讨论。 +> **说明:** 很多人经常会将“闭包”一词和[“匿名函数”](https://zh.wikipedia.org/wiki/%E5%8C%BF%E5%90%8D%E5%87%BD%E6%95%B0)混为一谈,但实际上它们是不同的概念,如果想提前了解这个概念,推荐看看[维基百科](https://zh.wikipedia.org/wiki/)或者[知乎](https://www.zhihu.com/)上对这个概念的讨论。 说了那么多,其实结论很简单,从现在开始我们可以将Python代码按照下面的格式进行书写,这一点点的改进其实就是在我们理解了函数和作用域的基础上跨出的巨大的一步。 diff --git a/Day01-15/Day07/res/formula_1.png b/Day01-15/Day07/res/formula_1.png new file mode 100644 index 0000000000000000000000000000000000000000..28fad34605c31264b6d9591cf4ca92f030143b6c GIT binary patch literal 816 zcmeAS@N?(olHy`uVBq!ia0vp^mw;G^g&9cRiJyBENErn9gt-3y{~yRC9_Zg)Pz_Yg zUlQaO%n*{Mi1{wRu@gr21;=jctjR6Fz_7#VaBQ2e9{aIOx>O?jv*F; zb3=VIgaZZsZHl~HJKH1pNWg_dLI>r%68Ik-?1-FF)gjjG5z4~ZF=-nIqvM{hl`Gk8 zkE|A()h)JH;sgI1)h|yDI)|*P(60EX5ENzeV(Ga(e?8;2a26({@B6uL=G@xf_tXyj zpY@dILgop^uHD}4yE@}`hQ3|;?P6NP8Ap8`p_c-!AL}?mY*wZ=tLn}ut>LUXlX~-N z?4G59ySL^nI8u+xr6TI~CYH}%@GE!JxF_-|Tm6#i1lg}Eb@ z|HYfF6Q?O1`jKzSDiWjP86+&ikPm|;A9QB(A1RIjy zWNp>eSQ6r9lG&-Y)1k(6#YVrJq@Is~>Ip8MenmM5wyULxNYY!Yt1)W}t| zRqC9_v7^#&UKV;+EN$5NW>p5mGqZ!YvxL5xic0VJAtv_IPU~3a(OH^h5AW>gu0F7# z{qMeCA9i+W@<-b#hF#H^)sh}+y7Hv^R?o^W-;S`Q`ObRcUh~!3dHszq>tp%ePkx)A zC-BK%LPQ|?dyU$^Wo`}EzhnsCIIMnXT2ouujoUwF9enS0bcwrH+&29*SKCPDxkbN< z?AvsH2u*L{Y#Hq#W!~v>2~ak zNjbK6Meo7Lj?9&Y)%sHtYX1AgJ4HRd&FP!e-7EL4@!8v3E1fsIlG+}uyZH(N)qkfP|NUa`lNa&MHmTa>SL_lV6|ysW+jGwis?V|fo4tt3 a`4NA_#=d~{>2ixfiQd!I&t;ucLK6VIv}3UV literal 0 HcmV?d00001 diff --git a/Day01-15/Day07/res/formula_2.png b/Day01-15/Day07/res/formula_2.png new file mode 100644 index 0000000000000000000000000000000000000000..86df5daca0112e17c5e9bcd590f31d10ccba8d28 GIT binary patch literal 365 zcmeAS@N?(olHy`uVBq!ia0vp^CP2*3!VDxMUw_;NqznRlLR|m<{|{sm5A^RYs0OO$ zFA4GsW)PTpcX!#@)gdlMooPz%e+ixV0F>e^@Q5sCVBk9f!i-b3`J{n@Cp=voLnI_i zC)n~aI!d(7S2fEPIM;BDb&jKxqLfPX4#v6H1U*!Qcw3`FO#BqM)Hn1sxHu|(%sco` zMU+t!gb-< znvdZV*fdSw_p(M;NHxDWsc!Ulm&feV1E$4yPLJS&B&NL;V`H!yyWjG5wB8!0vj({-ZRBb+Kpx`u57sn6@$>fBD zkh&#HK22fd?eJmX+#qUT;IiQ49Xs}EkFpaIX0)muJ-|L~mimFC279ESu-ih;z$f9sO`b=}j2lFPnLM5tO)}`g)ivqPcfi0;vq;@xW|2uL%ydZ<<%yWcer P=t2fhS3j3^P6avFbDT4r?5ZC|z{{xxC1O2-Ts)4Hc zOM?7@83bnD-CcHeb%={mXPVOcUqUB70Hrt!JR*x382FBWFymBhK4}I9rbZC=^u=0z2OJR2iyI(EJ|+U)veQHOSfVAlrmmkZfhFFw%caXLEt zql(v2Tai7-!bnuk8$130^66H(XD?R5fY-$IO6laV&BDR})!N52rUy zw$)Rb=~Xr>Y^~>kIt#8jmlu|G?aXgD9=MS0PV&X{&MPb1O--(U`ua;$*C4&iamuGc zy_!GlM|JYDRlU@LUMAMIDnCSzj?ZD^J~W)3#VA_K4=lmBAS{YcHNKYwvlr z@z|bidD~}v({cM<{bXP8+{h2p4}A)eE-9b>a!ZWT>OBh4WykNnK6rQQd6{PgNk`Ik z#4h@5zFCs|JL1os1&1nQ4ux#q$#7xn()SO9HgUT~Hq`FB{dd*hmXtdWq+W|IQNFdG zKh*3b`;loMZ{HADvE-oejBoGv2+RKLXtV9nV3*mnZdLHkokv^WzSi`O*5$l(wCwv(3%=PHY7waZgu2 Jmvv4FO#uA`U`_x4 literal 0 HcmV?d00001 diff --git a/Day01-15/Day07/字符串和常用数据结构.md b/Day01-15/Day07/字符串和常用数据结构.md index 5dff114..881b650 100644 --- a/Day01-15/Day07/字符串和常用数据结构.md +++ b/Day01-15/Day07/字符串和常用数据结构.md @@ -2,7 +2,7 @@ ### 使用字符串 -第二次世界大战促使了现代电子计算机的诞生,当初的想法很简单,就是用计算机来计算导弹的弹道,因此在计算机刚刚诞生的那个年代,计算机处理的信息主要是数值,而世界上的第一台电子计算机ENIAC每秒钟能够完成约5000次浮点运算。随着时间的推移,虽然对数值运算仍然是计算机日常工作中最为重要的事情之一,但是今天的计算机处理得更多的数据都是以文本信息的方式存在的,而Python表示文本信息的方式我们在很早以前就说过了,那就是字符串类型。所谓**字符串**,就是由零个或多个字符组成的有限序列,一般记为[$${\displaystyle s=a_{1}a_{2}\dots a_{n}(0\leq n \leq \infty)}$$](https://wikimedia.org/api/rest_v1/media/math/render/svg/e29bf631b090323edd6889f810e6cff29538b161)。 +第二次世界大战促使了现代电子计算机的诞生,当初的想法很简单,就是用计算机来计算导弹的弹道,因此在计算机刚刚诞生的那个年代,计算机处理的信息主要是数值,而世界上的第一台电子计算机ENIAC每秒钟能够完成约5000次浮点运算。随着时间的推移,虽然对数值运算仍然是计算机日常工作中最为重要的事情之一,但是今天的计算机处理得更多的数据都是以文本信息的方式存在的,而Python表示文本信息的方式我们在很早以前就说过了,那就是字符串类型。所谓**字符串**,就是由零个或多个字符组成的有限序列,一般记为![](./res/formula_1.png)。 我们可以通过下面的代码来了解字符串的使用。 @@ -183,11 +183,11 @@ if __name__ == '__main__': 除了上面提到的生成器语法,Python中还有另外一种定义生成器的方式,就是通过`yield`关键字将一个普通函数改造成生成器函数。下面的代码演示了如何实现一个生成[斐波拉切数列](https://zh.wikipedia.org/wiki/%E6%96%90%E6%B3%A2%E9%82%A3%E5%A5%91%E6%95%B0%E5%88%97)的生成器。所谓斐波拉切数列可以通过下面[递归](https://zh.wikipedia.org/wiki/%E9%80%92%E5%BD%92)的方法来进行定义: -$${\displaystyle F_{0}=0}$$ +![](./res/formula_2.png) -$${\displaystyle F_{1}=1}$$ +![](./res/formula_3.png) -$${\displaystyle F_{n}=F_{n-1}+F_{n-2}}({n}\geq{2})$$ +![](./res/formula_4.png) ![](./res/fibonacci-blocks.png) @@ -307,7 +307,7 @@ if __name__ == '__main__': main() ``` -> **说明**:Python中允许通过一些特殊的方法来为某种类型或数据结构自定义运算符(后面的章节中会讲到),上面的代码中我们对集合进行运算的时候可以调用集合对象的方法,也可以直接使用对应的运算符,例如`&`运算符跟intersection方法的作用就是一样的,但是使用运算符让代码更加直观。 +> **说明:** Python中允许通过一些特殊的方法来为某种类型或数据结构自定义运算符(后面的章节中会讲到),上面的代码中我们对集合进行运算的时候可以调用集合对象的方法,也可以直接使用对应的运算符,例如`&`运算符跟intersection方法的作用就是一样的,但是使用运算符让代码更加直观。 ### 使用字典 @@ -530,7 +530,7 @@ if __name__ == '__main__': main() ``` -> **说明**:上面使用random模块的sample函数来实现从列表中选择不重复的n个元素。 +> **说明:** 上面使用random模块的sample函数来实现从列表中选择不重复的n个元素。 #### 综合案例2:[约瑟夫环问题](https://zh.wikipedia.org/wiki/%E7%BA%A6%E7%91%9F%E5%A4%AB%E6%96%AF%E9%97%AE%E9%A2%98) @@ -609,4 +609,4 @@ if __name__ == '__main__': main() ``` ->**说明**:最后这个案例来自[《Python编程快速上手:让繁琐工作自动化》](https://item.jd.com/11943853.html)一书(这本书对有编程基础想迅速使用Python将日常工作自动化的人来说还是不错的选择),对代码做了一点点的调整。 \ No newline at end of file +>**说明:** 最后这个案例来自[《Python编程快速上手:让繁琐工作自动化》](https://item.jd.com/11943853.html)一书(这本书对有编程基础想迅速使用Python将日常工作自动化的人来说还是不错的选择),对代码做了一点点的调整。 \ No newline at end of file diff --git a/Day01-15/Day08/面向对象编程基础.md b/Day01-15/Day08/面向对象编程基础.md index b4f4856..220d71c 100644 --- a/Day01-15/Day08/面向对象编程基础.md +++ b/Day01-15/Day08/面向对象编程基础.md @@ -8,13 +8,13 @@ ![](./res/oop-zhihu.png) -> **说明**:以上的内容来自于网络,不代表作者本人的观点和看法,与作者本人立场无关,相关责任不由作者承担。 +> **说明:** 以上的内容来自于网络,不代表作者本人的观点和看法,与作者本人立场无关,相关责任不由作者承担。 之前我们说过“程序是指令的集合”,我们在程序中书写的语句在执行时会变成一条或多条指令然后由CPU去执行。当然为了简化程序的设计,我们引入了函数的概念,把相对独立且经常重复使用的代码放置到函数中,在需要使用这些功能的时候只要调用函数即可;如果一个函数的功能过于复杂和臃肿,我们又可以进一步将函数继续切分为子函数来降低系统的复杂性。但是说了这么多,不知道大家是否发现,所谓编程就是程序员按照计算机的工作方式控制计算机完成各种任务。但是,计算机的工作方式与正常人类的思维模式是不同的,如果编程就必须得抛弃人类正常的思维方式去迎合计算机,编程的乐趣就少了很多,“每个人都应该学习编程”这样的豪言壮语就只能说说而已。当然,这些还不是最重要的,最重要的是当我们需要开发一个复杂的系统时,代码的复杂性会让开发和维护工作都变得举步维艰,所以在上世纪60年代末期,“[软件危机](https://zh.wikipedia.org/wiki/%E8%BD%AF%E4%BB%B6%E5%8D%B1%E6%9C%BA)”、“[软件工程](https://zh.wikipedia.org/wiki/%E8%BD%AF%E4%BB%B6%E5%B7%A5%E7%A8%8B)”等一系列的概念开始在行业中出现。 当然,程序员圈子内的人都知道,现实中并没有解决上面所说的这些问题的“[银弹](https://zh.wikipedia.org/wiki/%E6%B2%A1%E6%9C%89%E9%93%B6%E5%BC%B9)”,真正让软件开发者看到希望的是上世纪70年代诞生的[Smalltalk](https://zh.wikipedia.org/wiki/Smalltalk)编程语言中引入的面向对象的编程思想(面向对象编程的雏形可以追溯到更早期的[Simula](https://zh.wikipedia.org/wiki/Simula)语言)。按照这种编程理念,程序中的数据和操作数据的函数是一个逻辑上的整体,我们称之为“对象”,而我们解决问题的方式就是创建出需要的对象并向对象发出各种各样的消息,多个对象的协同工作最终可以让我们构造出复杂的系统来解决现实中的问题。 -> **说明**:当然面向对象也不是解决软件开发中所有问题的最后的“银弹”,所以今天的高级程序设计语言几乎都提供了对多种编程范式的支持,Python也不例外。 +> **说明:** 当然面向对象也不是解决软件开发中所有问题的最后的“银弹”,所以今天的高级程序设计语言几乎都提供了对多种编程范式的支持,Python也不例外。 ### 类和对象 @@ -47,7 +47,7 @@ class Student(object): print('%s正在观看岛国爱情动作片.' % self.name ``` -> **说明**:写在类中的函数,我们通常称之为(对象的)方法,这些方法就是对象可以接收的消息。 +> **说明:** 写在类中的函数,我们通常称之为(对象的)方法,这些方法就是对象可以接收的消息。 ### 创建和使用对象 @@ -237,4 +237,4 @@ if __name__ == '__main__': main() ``` -> **说明**:本章中的插图来自于Grady Booch等著作的[《面向对象分析与设计》](https://item.jd.com/20476561918.html)一书,该书是讲解面向对象编程的经典著作,有兴趣的读者可以购买和阅读这本书来了解更多的面向对象的相关知识。 \ No newline at end of file +> **说明:** 本章中的插图来自于Grady Booch等著作的[《面向对象分析与设计》](https://item.jd.com/20476561918.html)一书,该书是讲解面向对象编程的经典著作,有兴趣的读者可以购买和阅读这本书来了解更多的面向对象的相关知识。 \ No newline at end of file diff --git a/Day01-15/Day09/面向对象进阶.md b/Day01-15/Day09/面向对象进阶.md index 168884d..956d910 100644 --- a/Day01-15/Day09/面向对象进阶.md +++ b/Day01-15/Day09/面向对象进阶.md @@ -636,7 +636,7 @@ if __name__ == '__main__': main() ``` ->**说明**:大家可以自己尝试在上面代码的基础上写一个简单的扑克游戏,例如21点(Black Jack),游戏的规则可以自己在网上找一找。 +>**说明:** 大家可以自己尝试在上面代码的基础上写一个简单的扑克游戏,例如21点(Black Jack),游戏的规则可以自己在网上找一找。 #### 案例3:工资结算系统 diff --git a/Day01-15/Day10/图形用户界面和游戏开发.md b/Day01-15/Day10/图形用户界面和游戏开发.md index 6dfada7..ae65624 100644 --- a/Day01-15/Day10/图形用户界面和游戏开发.md +++ b/Day01-15/Day10/图形用户界面和游戏开发.md @@ -128,7 +128,7 @@ if __name__ == '__main__': main() ``` -####加载图像 +#### 加载图像 如果需要直接加载图像到窗口上,可以使用pygame中image模块的函数来加载图像,再通过之前获得的窗口对象的`blit`方法渲染图像,代码如下所示。 @@ -164,7 +164,7 @@ if __name__ == '__main__': main() ``` -####实现动画效果 +#### 实现动画效果 说到[动画](https://zh.wikipedia.org/wiki/%E5%8A%A8%E7%94%BB)这个词大家都不会陌生,事实上要实现动画效果,本身的原理也非常简单,就是将不连续的图片连续的播放,只要每秒钟达到了一定的帧数,那么就可以做出比较流畅的动画效果。如果要让上面代码中的小球动起来,可以将小球的位置用变量来表示,并在循环中修改小球的位置再刷新整个窗口即可。 diff --git a/Day01-15/Day11/文件和异常.md b/Day01-15/Day11/文件和异常.md index 924aef9..ff707e3 100644 --- a/Day01-15/Day11/文件和异常.md +++ b/Day01-15/Day11/文件和异常.md @@ -174,14 +174,14 @@ if __name__ == '__main__': ```JSON { - 'name': '骆昊', - 'age': 38, - 'qq': 957658, - 'friends': ['王大锤', '白元芳'], - 'cars': [ - {'brand': 'BYD', 'max_speed': 180}, - {'brand': 'Audi', 'max_speed': 280}, - {'brand': 'Benz', 'max_speed': 320} + "name": "骆昊", + "age": 38, + "qq": 957658, + "friends": ["王大锤", "白元芳"], + "cars": [ + {"brand": "BYD", "max_speed": 180}, + {"brand": "Audi", "max_speed": 280}, + {"brand": "Benz", "max_speed": 320} ] } ``` diff --git a/Day01-15/Day12/字符串和正则表达式.md b/Day01-15/Day12/字符串和正则表达式.md index 418d039..b8b9ae9 100644 --- a/Day01-15/Day12/字符串和正则表达式.md +++ b/Day01-15/Day12/字符串和正则表达式.md @@ -32,7 +32,7 @@ | \| | 分支 | foo\|bar | 可以匹配foo或者bar | | (?#) | 注释 | | | | (exp) | 匹配exp并捕获到自动命名的组中 | | | -| (?<name>exp) | 匹配exp并捕获到名为name的组中 | | | +| (? <name>exp) | 匹配exp并捕获到名为name的组中 | | | | (?:exp) | 匹配exp但是不捕获匹配的文本 | | | | (?=exp) | 匹配exp前面的位置 | \\b\\w+(?=ing) | 可以匹配I'm dancing中的danc | | (?<=exp) | 匹配exp后面的位置 | (?<=\\bdanc)\\w+\\b | 可以匹配I love dancing and reading中的第一个ing | @@ -44,7 +44,7 @@ | {M,N}? | 重复M到N次,但尽可能少重复 | | | | {M,}? | 重复M次以上,但尽可能少重复 | | | -> **说明:**如果需要匹配的字符是正则表达式中的特殊字符,那么可以使用\\进行转义处理,例如想匹配小数点可以写成\\.就可以了,因为直接写.会匹配任意字符;同理,想匹配圆括号必须写成\\(和\\),否则圆括号被视为正则表达式中的分组。 +> **说明:** 如果需要匹配的字符是正则表达式中的特殊字符,那么可以使用\\进行转义处理,例如想匹配小数点可以写成\\.就可以了,因为直接写.会匹配任意字符;同理,想匹配圆括号必须写成\\(和\\),否则圆括号被视为正则表达式中的分组。 ### Python对正则表达式的支持 @@ -64,7 +64,7 @@ Python提供了re模块来支持正则表达式相关操作,下面是re模块 | re.I / re.IGNORECASE | 忽略大小写匹配标记 | | re.M / re.MULTILINE | 多行匹配标记 | -> **说明:**上面提到的re模块中的这些函数,实际开发中也可以用正则表达式对象的方法替代对这些函数的使用,如果一个正则表达式需要重复的使用,那么先通过compile函数编译正则表达式并创建出正则表达式对象无疑是更为明智的选择。 +> **说明:** 上面提到的re模块中的这些函数,实际开发中也可以用正则表达式对象的方法替代对这些函数的使用,如果一个正则表达式需要重复的使用,那么先通过compile函数编译正则表达式并创建出正则表达式对象无疑是更为明智的选择。 下面我们通过一系列的例子来告诉大家在Python中如何使用正则表达式。 @@ -98,7 +98,7 @@ if __name__ == '__main__': main() ``` -> **提示**:上面在书写正则表达式时使用了“原始字符串”的写法(在字符串前面加上了r),所谓“原始字符串”就是字符串中的每个字符都是它原始的意义,说得更直接一点就是字符串中没有所谓的转义字符啦。因为正则表达式中有很多元字符和需要进行转义的地方,如果不使用原始字符串就需要将反斜杠写作\\\\,例如表示数字的\\d得书写成\\\\d,这样不仅写起来不方便,阅读的时候也会很吃力。 +> **提示:** 上面在书写正则表达式时使用了“原始字符串”的写法(在字符串前面加上了r),所谓“原始字符串”就是字符串中的每个字符都是它原始的意义,说得更直接一点就是字符串中没有所谓的转义字符啦。因为正则表达式中有很多元字符和需要进行转义的地方,如果不使用原始字符串就需要将反斜杠写作\\\\,例如表示数字的\\d得书写成\\\\d,这样不仅写起来不方便,阅读的时候也会很吃力。 #### 例子2:从一段文字中提取出国内手机号码。 @@ -136,7 +136,7 @@ if __name__ == '__main__': main() ``` -> **说明**:上面匹配国内手机号的正则表达式并不够好,因为像14开头的号码只有145或147,而上面的正则表达式并没有考虑这种情况,要匹配国内手机号,更好的正则表达式的写法是:`(?<=\D)(1[38]\d{9}|14[57]\d{8}|15[0-35-9]\d{8}|17[678]\d{8})(?=\D)`,国内最近好像有19和16开头的手机号了,但是这个暂时不在我们考虑之列。 +> **说明:** 上面匹配国内手机号的正则表达式并不够好,因为像14开头的号码只有145或147,而上面的正则表达式并没有考虑这种情况,要匹配国内手机号,更好的正则表达式的写法是:`(?<=\D)(1[38]\d{9}|14[57]\d{8}|15[0-35-9]\d{8}|17[678]\d{8})(?=\D)`,国内最近好像有19和16开头的手机号了,但是这个暂时不在我们考虑之列。 #### 例子3:替换字符串中的不良内容 @@ -155,7 +155,7 @@ if __name__ == '__main__': main() ``` -> **说明**:re模块的正则表达式相关函数中都有一个flags参数,它代表了正则表达式的匹配标记,可以通过该标记来指定匹配时是否忽略大小写、是否进行多行匹配、是否显示调试信息等。如果需要为flags参数指定多个值,可以使用[按位或运算符](http://www.runoob.com/python/python-operators.html#ysf5)进行叠加,如`flags=re.I | re.M`。 +> **说明:** re模块的正则表达式相关函数中都有一个flags参数,它代表了正则表达式的匹配标记,可以通过该标记来指定匹配时是否忽略大小写、是否进行多行匹配、是否显示调试信息等。如果需要为flags参数指定多个值,可以使用[按位或运算符](http://www.runoob.com/python/python-operators.html#ysf5)进行叠加,如`flags=re.I | re.M`。 #### 例子4:拆分长字符串 diff --git a/Day01-15/Day13/进程和线程.md b/Day01-15/Day13/进程和线程.md index c1d2093..befdc4c 100644 --- a/Day01-15/Day13/进程和线程.md +++ b/Day01-15/Day13/进程和线程.md @@ -320,7 +320,7 @@ if __name__ == '__main__': 除了计算密集型任务,其他的涉及到网络、存储介质I/O的任务都可以视为I/O密集型任务,这类任务的特点是CPU消耗很少,任务的大部分时间都在等待I/O操作完成(因为I/O的速度远远低于CPU和内存的速度)。对于I/O密集型任务,如果启动多任务,就可以减少I/O等待时间从而让CPU高效率的运转。有一大类的任务都属于I/O密集型任务,这其中包括了我们很快会涉及到的网络应用和Web应用。 -> **说明:**上面的内容和例子来自于[廖雪峰官方网站的《Python教程》](https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000),因为对作者文中的某些观点持有不同的看法,对原文的文字描述做了适当的调整。 +> **说明:** 上面的内容和例子来自于[廖雪峰官方网站的《Python教程》](https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000),因为对作者文中的某些观点持有不同的看法,对原文的文字描述做了适当的调整。 ### 单线程+异步I/O diff --git a/Day01-15/Day14-A/网络编程入门.md b/Day01-15/Day14-A/网络编程入门.md index a466865..234ca2d 100644 --- a/Day01-15/Day14-A/网络编程入门.md +++ b/Day01-15/Day14-A/网络编程入门.md @@ -70,9 +70,9 @@ JSON的例子: ```JSON { - 'from': 'Alice', - 'to': 'Bob', - 'content': 'Will you marry me?' + "from": "Alice", + "to": "Bob", + "content": "Will you marry me?" } ``` @@ -291,7 +291,7 @@ if __name__ == '__main__': 在这个案例中,我们使用了JSON作为数据传输的格式(通过JSON格式对传输的数据进行了序列化和反序列化的操作),但是JSON并不能携带二进制数据,因此对图片的二进制数据进行了Base64编码的处理。Base64是一种用64个字符表示所有二进制数据的编码方式,通过将二进制数据每6位一组的方式重新组织,刚好可以使用0~9的数字、大小写字母以及“+”和“/”总共64个字符表示从`000000`到`111111`的64种状态。[维基百科](https://zh.wikipedia.org/wiki/Base64)上有关于Base64编码的详细讲解,不熟悉Base64的读者可以自行阅读。 -> **说明**:上面的代码主要为了讲解网络编程的相关内容因此并没有对异常状况进行处理,请读者自行添加异常处理代码来增强程序的健壮性。 +> **说明:** 上面的代码主要为了讲解网络编程的相关内容因此并没有对异常状况进行处理,请读者自行添加异常处理代码来增强程序的健壮性。 #### UDP套接字