有哪些好的Python入门教程或资源推荐?
null
有哪些好的Python入门教程或资源推荐?
找一个现实的需求 比如批量处理数据 处理文件之类的鼓捣 了解一下语法和常用功能 然后看包管理 装饰器之类的‘高阶’概念 然后了解一下虚拟机处理流程 举个例子
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入门,我推荐这几个核心资源:
- 官方文档(docs.python.org)- 最权威的参考,适合随时查阅
- 《Python Crash Course》 - 实践性强,适合零基础快速上手
- Codecademy的Python课程 - 交互式学习,即时反馈
- Real Python教程 - 质量很高的实战文章和视频
- Coursera上的"Python for Everybody" - 系统化免费课程
建议从官方教程开始,配合一本入门书系统学习,再用交互平台练习。关键是多写代码,从小项目开始实践。
一句话总结:官方文档+一本好书+动手练习是最有效的入门路径。
代码没有缩进 你凑合着看吧
廖雪峰,系列教程都很棒。
我就是看他的教程学会的 py 和 git
但是他 git 教程感觉。。真的很一般吧
跟孩子一起学编程
我也是自学的 python,最初的时候是下载了一套相对比较新的视频讲座,用来掌握基本语法和一些编程思路
基础知识掌握了之后,以需求为导向,实际上手,一点点针对遇到的问题不断的 google (不要百度…对…不要百度…),多上 Stack Overflow,受益良多的
没有对比就没有伤害,不过单从上手容易程度上看,有一个 GitHub 项目专门介绍 Git 更容易上手点
看廖雪峰的,有的地方没看懂就去搜其他人讲的。
看他的目录,我觉得节奏还挺好的,可以按照他目录的顺序来学。
赞同~差不多入门后,遇到有难解决的问题,就把错误代码复制进 google,一般开头几条搜索结果就是 stackoverflow 的,效率超高~
看一下廖雪峰的教程就开始多用吧…
我也自学,看完 A Byte of Python 后,目前正在刷 Code Wars,刷完后准备上爬虫了,Web 应用不打算刷了。
慕课网找些教程过一遍?
http://www.imooc.com/course/list?c=python
作者自己也说了,不是 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 教程


