有哪些好的Python入门教程或资源推荐?

null
有哪些好的Python入门教程或资源推荐?

21 回复

找一个现实的需求 比如批量处理数据 处理文件之类的鼓捣 了解一下语法和常用功能 然后看包管理 装饰器之类的‘高阶’概念 然后了解一下虚拟机处理流程 举个例子
def append(v, ary=[]):
ary.append(v)
return ary

print(append(1)) # 结果是 [1]
print(append(2)) # 结果是 [1, 2]
这段代码整明白就能弄明白很多事情了(当然了,实际工程里这么写代码会被打死的)
然后就可以再了解一下 GC 啊 GIL 之类的
然后就 Cython PyPy 之类的边角料
在之后就是 Django flask spark 之类的具体应用


对于Python入门,我推荐这几个核心资源:

  1. 官方文档docs.python.org)- 最权威的参考,适合随时查阅
  2. 《Python Crash Course》 - 实践性强,适合零基础快速上手
  3. Codecademy的Python课程 - 交互式学习,即时反馈
  4. Real Python教程 - 质量很高的实战文章和视频
  5. Coursera上的"Python for Everybody" - 系统化免费课程

建议从官方教程开始,配合一本入门书系统学习,再用交互平台练习。关键是多写代码,从小项目开始实践。

一句话总结:官方文档+一本好书+动手练习是最有效的入门路径。

代码没有缩进 你凑合着看吧

廖雪峰,系列教程都很棒。
我就是看他的教程学会的 py 和 git

但是他 git 教程感觉。。真的很一般吧

跟孩子一起学编程

我也是自学的 python,最初的时候是下载了一套相对比较新的视频讲座,用来掌握基本语法和一些编程思路
基础知识掌握了之后,以需求为导向,实际上手,一点点针对遇到的问题不断的 google (不要百度…对…不要百度…),多上 Stack Overflow,受益良多的

没有对比就没有伤害,不过单从上手容易程度上看,有一个 GitHub 项目专门介绍 Git 更容易上手点

看廖雪峰的,有的地方没看懂就去搜其他人讲的。
看他的目录,我觉得节奏还挺好的,可以按照他目录的顺序来学。

赞同~差不多入门后,遇到有难解决的问题,就把错误代码复制进 google,一般开头几条搜索结果就是 stackoverflow 的,效率超高~

看一下廖雪峰的教程就开始多用吧…

我也自学,看完 A Byte of Python 后,目前正在刷 Code Wars,刷完后准备上爬虫了,Web 应用不打算刷了。

作者自己也说了,不是 git 专家,但是都是自己的经验。从一个使用者的角度来说我觉得还是相当实用的



放个链接额

我觉得 Git 比 Python 难学多了 …

怎么学正则表达式,心里有阴影了


下一个 RegexBuddy 软件,它帮助里自带的 tutorials 是最好的正则表达式教程。
另外,最好背下元字符表:
. * ? + ( ) [ ^ $ | <br>口决:点星问号加,小中大括号,头尾竖杠。

以前写的 Python 正则表达式笔记:
(参考资料:廖雪峰 Python 教程、正则指引)

re 模块包含所有正则表达式的功能。

在正则表达式内部插入匹配模式:

对大小写不敏感:(?i)
单行模式,即.匹配’\n’:(?s)
多行模式:(?m)
ASCII 模式,即\d、\w、\s 不会匹配非 ASCII 数字,字母和空格:(?a)
Unicode 模式,与 ASCII 模式相反,Python 3 的默认模式:(?u)
注释模式:(?x)

注意:Python 中的模式永远是对整个正则表达式生效的,无论(?..)出现在哪里; Python 不支持用(?-…)停用模式。

\A 匹配字符串的开始位置,\Z 匹配字符串的结束位置。Python 没有\z,\Z 相当于其它语言正则表达式的\z。
如果使用了命名分组,在正则表达式中应当使用(?P=name)来引用,在替换时应当使用\g<name>来引用。例如:r’(?P<char>[a-z])(?P=char)‘

观察某个正则表达式的详细信息:

>>> re.compile(r’(ab|[cde])+’, re.DEBUG)
max_repeat 1 2147483647
subpattern 1
branch
literal 97
literal 98
or
in
literal 99
literal 100
literal 101

re.compile(’(ab|[cde])+’, re.DEBUG)

Match 对象常用的方法和属性:

import re
m = re.search(r’(\d{4})-(\d{2})-(\d{2})’, ‘2010-12-20’)
print(’%s start at %d and ends at %d’ % (m.group(), m.pos, m.endpos))
for i in range(1, m.lastindex + 1): # 最大分组的编号
print(’%s start at %d and ends at %d’ %
(m.group(i), m.start(i), m.end(i)))
print(m.expand(r’year:\1 month:\2 day:\3’))

运行结果:

2010-12-20 start at 0 and ends at 10
2010 start at 0 and ends at 4
12 start at 5 and ends at 7
20 start at 8 and ends at 10
year:2010 month:12 day:20

常用操作示例:

import re

# 1. 验证与搜索

# 如果找到,search()方法返回一个 Match 对象,否则返回 None
if re.search(r’\A\d{4}-\d{2}-\d{2}\Z’, ‘2010-12-20’):
print(‘ok’)

# 如果一个正则表达式要反复使用,可以先编译它,以提高效率
dateRegex = re.compile(r’\A\d{4}-\d{2}-\d{2}\Z’)
if dateRegex.search(‘2010-12-20’): # 或 re.search(dateRegex, ‘2010-12-20’)
print(‘ok’)

# Match 对象的 group()和 groups()方法
phoneNumRegex = re.compile(r’(\d\d\d)-(\d\d\d-\d\d\d\d)’)
m = phoneNumRegex.search(‘My number is 415-555-4242.’)
print(m.group()) # 输出:415-555-4242
print(m.group(0)) # 输出:415-555-4242
print(m.group(1)) # 输出:415
print(m.group(2)) # 输出:555-4242
# 一次性获取从 1 开始的所有的分组
print(m.groups()) # 输出:(‘415’, ‘555-4242’)

# match()和 search()非常相似,参数和返回值都相同,唯一的区别在于:
# match()只会从字符串的最左端开始匹配,search()则没有这个限制。

# 2. 提取

# findall()方法返回一个字符串列表或一个元组列表,没找到则返回一个空列表
print(re.findall(r’\d{4}-\d{2}-\d{2}’, ‘2010-12-20 2011-02-14’))
# 输出:[‘2010-12-20’, ‘2011-02-14’]
print(re.findall(r’(\d{4})-(\d{2})-(\d{2})’, ‘2010-12-20 2011-02-14’))
# 输出:[(‘2010’, ‘12’, ‘20’), (‘2011’, ‘02’, ‘14’)]

# 使用 finditer()迭代查找
for iter in re.finditer(r’(\d{4})-(\d{2}-(\d{2}))’, ‘2010-12-20 2011-02-14’):
print(iter.group()) # iter 是一个 Match 对象
# 输出:2010-12-20
# 输出:2011-02-14

# 使用命名分组
regex = re.compile(r’(?P<year>\d{4})-(?P<month>\d{2})-(?P<day>\d{2})’)
for iter in regex.finditer(‘2010-12-20 2011-02-14’):
print(iter.group(‘year’), iter.group(‘month’), iter.group(‘day’))

# 3. 替换

print(re.sub(r’\d+’, r’**’, ‘She is 22 years old.’))
# 输出:She is ** years old.

regex = r’(\d{4})-(\d{2})-(\d{2})‘
replacement = r’\2/\3/\1’ # 或 r’\g<2>/\g<3>/\g<1>‘
print(re.sub(regex, replacement, ‘2010-12-20’))
# 输出:12/20/2010

# 使用命名分组
regex = r’(?P<year>\d{4})-(?P<month>\d{2})-(?P<day>\d{2})‘
replacement = r’\g<month>/\g<day>/\g<year>‘
print(re.sub(regex, replacement, ‘2010-12-20’))
# 输出:12/20/2010

# 在替换中使用整个表达式匹配的文本
regex = r’\d+.\d{0,2}‘
replacement = r’$\g<0>‘
print(re.sub(regex, replacement, ‘the price is 12.99’))
# 输出:the price is $12.99

# 指定替换操作最多发生的次数:
print(re.sub(r’\d+’, ‘x’, ‘13 + 76 = 89’, 1))
# 输出:x + 76 = 89

# 将所有单词统一为首字母大写其余字母小写格式:
def capitalize(match):
return match.group(1).upper() + match.group(2).lower()
result = re.sub(r’(?i)\b([a-z])([a-z]+)\b’, capitalize, ‘one tWO THREE’)
print(result)
# 输出:One Two Three

# 4. 切分字符串
print(re.split(r’\s+’, 'a b \t\r\n c '))
# 输出:[‘a’, ‘b’, ‘c’, ‘’]

话说楼主的头像真的很赞!

不好意思, 找了很久没找到,刚才在睡觉的时候突然想起来,然后 Google 了一下 How to learn git,第一个就是: https://try.github.io/levels/1/challenges/1 :)

简明 Python 教程

回到顶部