[Python基础]004.语法(3)
语法(3)
方法
定义
- 语法 def 方法名(参数):
- 返回值 return没有指定返回值的方法,默认返回空值None。
代码
def say(who, dosth):
'''
谁做什么
'''
print who + ' ' + dosth + '!'
return
调用
- 方法名(参数)- say('AC', 'say hello')- 输出:AC say hello! 
- 方法名(参数名=参数)
 Python解释器能够用参数名匹配参数值,- say(who='Horse', dosth='run') 
 # 或者
 say(dosth='run', who='Horse') # 顺序不影响- 输出:Horse run! 
参数
- 引用方式传递参数
 除字符串和数字外,Python的其他对象全都采用引用方式传递参数,当参数在方法里被修改时,原始参数也被修改。- a = [1, 2, 3, 4] def fun(i): 
 a.append(5) fun(a) print a- 输出: [1, 2, 3, 4, 5] 
- 默认参数
 在定义方法时,在参数名后加上- =和- 默认值。
 这些默认参数是- 可选的,调用时可以不填,直接使用默认值。- def say(who, dosth='say hello'): # dosth定义了默认参数 
 '''
 谁做什么
 '''
 print who + ' ' + dosth + '!'
 return say('I') # 只要填写一个参数,另一个没写时使用默认参数- 输出: I say hello! 
返回 return
跳出方法,返回一个值。
def add(a, b):
return a + b c = add(1, 2)
print c
输出: 3
模块
模块就是一个Python文件,后缀名为.py。
将方法,变量,类等定义在模块里,方便被其他程序引用,使用其中定义的功能。
引入模块
- import
 导入模块,以调用 Python标准库- os为例。- import os # 引入os模块 
 os.mkdir('abc') # 调用方法,创建abc文件夹 import os.path # 引入os.path模块
 os.path.isfile('xxx.png') # 调用方法,判断是否是文件- 导入模块后,需要以 - 模块名.方法名来调用模块下面的方法。
- from ... import ...
 直接从模块中导入方法,变量或类,还是以- os为例。- from os import mkdir # 从os引入mkdir方法 
 mkdir('abc') # 调用方法 from os.path import isfile # 从os.path引入isfile方法
 isfile('xxx.png') # 调用方法- 这种方式直接从模块中引入某个方法,在调用时就可以直接用 - 方法名。
- from ... import *从模块中导入所有东西。- from os import * # 引入os的所有东西 
 mkdir('abc') from os.path import * # 引入os.path的所有东西
 isfile('xxx.png')
- as
 模块别名- import os.path as path # 引入os.path模块 别名path 
 path.isfile('xxx.png') # 调用方法- 使用别名后,就可以直接用别名来代替模块名。 
写模块
写一个模块,其实就是写一个Python文件。
# MyModule.py def test(): # 方法
print 'my module test' var1 = 10 # 变量 class C: # 类
def __init__(self):
pass
上面就是一个简单的模块 MyModule.py 。
# main.py import MyModule # 引入模块
MyModule.test() # 调用test方法
print MyModule.var1 # 模块变量 from MyModule import C # 导入类
另一个模块调用 MyModule 模块的方法。
模块名称 __name__
每个模块都有一个名称,可以使用 __name__ 属性来获得。
最常用的地方就是作为main方法入口。
# MyModule.py # ...模块定义... if __name__ == '__main__':
# 当模块名是 __main__ 时,执行
print 'MyModule main'
当直接执行这个模块时,其模块名就是 __main__ 。
当该模块是用 import 导入时,就不会执行。
dir()
dir() 方法用来找到模块内所有东西的名称。
import os.path
dir(os.path)
返回一个字符串列表:
['__all__', '__builtins__', '__doc__', '__file__', '__name__',
'__package__', '_joinrealpath', '_unicode', '_uvarprog', '_varprog',
'abspath', 'altsep', 'basename', 'commonprefix', 'curdir', 'defpath',
'devnull', 'dirname', 'exists', 'expanduser', 'expandvars', 'extsep',
'genericpath', 'getatime', 'getctime', 'getmtime', 'getsize', 'isabs',
'isdir', 'isfile', 'islink', 'ismount', 'join', 'lexists', 'normcase',
'normpath', 'os', 'pardir', 'pathsep', 'realpath', 'relpath', 'samefile',
'sameopenfile', 'samestat', 'sep', 'split', 'splitdrive', 'splitext',
'stat', 'supports_unicode_filenames', 'sys', 'walk', 'warnings']

本站文章为宝宝巴士 SD.Team原创,转载务必在明显处注明:(作者官方网站:宝宝巴士) 
转载自【宝宝巴士SuperDo团队】 原文链接: http://www.cnblogs.com/superdo/p/4512799.html
 *:first-child {
  margin-top: 0 !important; }
body > *:last-child {
  margin-bottom: 0 !important; }
a {
  color: #4183C4;
  text-decoration: none; }
a.absent {
  color: #cc0000; }
a.anchor {
  display: block;
  padding-left: 30px;
  margin-left: -30px;
  cursor: pointer;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0; }
h1, h2, h3, h4, h5, h6 {
  margin: 20px 0 10px;
  padding: 0;
  font-weight: bold;
  -webkit-font-smoothing: antialiased;
  cursor: text;
  position: relative; }
h1:hover a.anchor, h2:hover a.anchor, h3:hover a.anchor, h4:hover a.anchor, h5:hover a.anchor, h6:hover a.anchor {
  background: url() no-repeat 10px center;
  text-decoration: none; }
h1 tt, h1 code {
  font-size: inherit; }
h2 tt, h2 code {
  font-size: inherit; }
h3 tt, h3 code {
  font-size: inherit; }
h4 tt, h4 code {
  font-size: inherit; }
h5 tt, h5 code {
  font-size: inherit; }
h6 tt, h6 code {
  font-size: inherit; }
h1 {
  font-size: 28px;
  color: black; }
h2 {
  font-size: 24px;
  border-bottom: 1px solid #cccccc;
  color:#00ccff;
  margin: 25px auto 12px auto;
  padding-bottom: 2px;
}
h3 {
  font-size: 18px;
  color:#993300;}
h4 {
  font-size: 16px; }
h5 {
  font-size: 14px; }
h6 {
  color: #777777;
  font-size: 14px; }
p, blockquote, ul, ol, dl, li, table, pre {
  margin: 0 0; }
/*hr {
  background: transparent url() repeat-x 0 0;
  border: 0 none;
  color: #cccccc;
  height: 4px;
  padding: 0;
}*/
hr {
    margin: 0 0 19px;
    border: 0;
    border-bottom: 1px solid #ccc;
}
body > h2:first-child {
  margin-top: 0;
  padding-top: 0; }
body > h1:first-child {
  margin-top: 0;
  padding-top: 0; }
  body > h1:first-child + h2 {
    margin-top: 0;
    padding-top: 0; }
body > h3:first-child, body > h4:first-child, body > h5:first-child, body > h6:first-child {
  margin-top: 0;
  padding-top: 0; }
a:first-child h1, a:first-child h2, a:first-child h3, a:first-child h4, a:first-child h5, a:first-child h6 {
  margin-top: 0;
  padding-top: 0; }
h1 p, h2 p, h3 p, h4 p, h5 p, h6 p {
  margin-top: 0; }
li p.first {
  display: inline-block; }
li {
  margin: 0; }
ul, ol {
  padding-left: 30px; }
ul :first-child, ol :first-child {
  margin-top: 0; }
dl {
  padding: 0; }
  dl dt {
    font-size: 14px;
    font-weight: bold;
    font-style: italic;
    padding: 0;
    margin: 15px 0 5px; }
    dl dt:first-child {
      padding: 0; }
    dl dt > :first-child {
      margin-top: 0; }
    dl dt > :last-child {
      margin-bottom: 0; }
  dl dd {
    margin: 0 0 15px;
    padding: 0 15px; }
    dl dd > :first-child {
      margin-top: 0; }
    dl dd > :last-child {
      margin-bottom: 0; }
blockquote {
  border-left: 4px solid #dddddd;
  padding: 0 15px;
  color: #777777; }
  blockquote > :first-child {
    margin-top: 0; }
  blockquote > :last-child {
    margin-bottom: 0; }
/*table {
  padding: 0;border-collapse: collapse; }
  table tr {
    border-top: 1px solid #cccccc;
    background-color: white;
    margin: 0;
    padding: 0; }
    table tr:nth-child(2n) {
      background-color: #f8f8f8; }
    table tr th {
      font-weight: bold;
      border: 1px solid #cccccc;
      margin: 0;
      padding: 6px 13px; }
    table tr td {
      border: 1px solid #cccccc;
      margin: 0;
      padding: 6px 13px; }
    table tr th :first-child, table tr td :first-child {
      margin-top: 0; }
    table tr th :last-child, table tr td :last-child {
      margin-bottom: 0; }*/
img {
  max-width: 100%; }
span.frame {
  display: block;
  overflow: hidden; }
  span.frame > span {
    border: 1px solid #dddddd;
    display: block;
    float: left;
    overflow: hidden;
    margin: 13px 0 0;
    padding: 7px;
    width: auto; }
  span.frame span img {
    display: block;
    float: left; }
  span.frame span span {
    clear: both;
    color: #333333;
    display: block;
    padding: 5px 0 0; }
span.align-center {
  display: block;
  overflow: hidden;
  clear: both; }
  span.align-center > span {
    display: block;
    overflow: hidden;
    margin: 13px auto 0;
    text-align: center; }
  span.align-center span img {
    margin: 0 auto;
    text-align: center; }
span.align-right {
  display: block;
  overflow: hidden;
  clear: both; }
  span.align-right > span {
    display: block;
    overflow: hidden;
    margin: 13px 0 0;
    text-align: right; }
  span.align-right span img {
    margin: 0;
    text-align: right; }
span.float-left {
  display: block;
  margin-right: 13px;
  overflow: hidden;
  float: left; }
  span.float-left span {
    margin: 13px 0 0; }
span.float-right {
  display: block;
  margin-left: 13px;
  overflow: hidden;
  float: right; }
  span.float-right > span {
    display: block;
    overflow: hidden;
    margin: 13px auto 0;
    text-align: right; }
code, tt {
  margin: 0 2px;
  padding: 0 0px;
  white-space: nowrap;
  /*background-color: #fff;*/
  color: rgba(51, 102, 255, 255);
  /*border: 1px solid #eaeaea;*/
  /*background-color: #f8f8f8;*/
  /*border-radius: 3px; */}
pre code {
  margin: 0;
  padding: 0;
  white-space: pre;
  border: none;
  color: rgba(0, 0, 0, 255);
  background: transparent; }
.highlight pre {
  background-color: #f8f8f8;
  border: 1px solid #cccccc;
  font-size: 13px;
  line-height: 19px;
  overflow: auto;
  padding: 6px 10px;
  border-radius: 3px; }
pre {
  background-color: #f8f8f8;
  border: 1px solid #cccccc;
  font-size: 14px;
  line-height: 19px;
  overflow: auto;
  padding: 6px 10px;
  border-radius: 3px; }
  pre code, pre tt {
    background-color: transparent;
    border: none; }
sup {
    font-size: 0.83em;
    vertical-align: super;
    line-height: 0;
}
* {
	-webkit-print-color-adjust: exact;
}
@media screen and (min-width: 914px) {
    body {
        /*width: 854px;*/
        /*margin:0 auto;*/
    }
}
@media print {
	table, pre {
		page-break-inside: avoid;
	}
	pre {
		word-wrap: break-word;
	}
}
#cnblogs_post_body li ul li {
    list-style-type: circle !important;
}
#cnblogs_post_body a {
    text-decoration: none;
    color: #4183C4;
}
#mainContent .postBody h2 {
  margin: 25px auto 12px auto;
  padding-bottom: 2px;
}
-->
[Python基础]004.语法(3)的更多相关文章
- 六. Python基础(6)--语法
		六. Python基础(6)--语法 1 ● Python3中, Unicode转字节的方法 print(bytes("李泉", encoding = 'utf-8')) prin ... 
- 五. Python基础(5)--语法
		五. Python基础(5)--语法 1 ● break结束的是它所在的循环体, continue是让它所在的循环体继续循环 # 打印: 1 10 2 10 3 10 4 10 5 10 6 10 7 ... 
- 四. Python基础(4)--语法
		四. Python基础(4)--语法 1 ● 比较几种实现循环的代码 i = 1 sum = 0 while i <= 10: # 循环10-1+1=10次 sum += i i ... 
- 三. Python基础(3)--语法
		三. Python基础(3)--语法 1. 字符串格式化的知识补充 tpl = "我是%s,年龄%d,学习进度100%" %('Arroz',18) print(tpl) # 会提 ... 
- 二. Python基础(2)--语法
		二. Python基础(2)--语法 1.实现一个简单的登录系统 '''# 形式1 n = 1 while n < 4: name = input("请输入姓名\n" ... 
- 一. Python基础(1)--语法
		一. Python基础(1)--语法 1. 应用程序 1.1 什么是计算机(Computer)? 组成 ①运算器 arithmetic unit; ※ Arithmetic unit and cont ... 
- Python基础:语法基础(3)
		本篇主要介绍Python中一些基础语法,其中包括:标识符.关键字.常量.变量.表达式.语句.注释.模块和包等内容. 1. 标识符和关键字 1.1 标识符 标识符是变量.常量.函数.属性.类.模块和包等 ... 
- Python基础__Python语法基础、条件、循环
		之前主要讨论的是Python的对象,这本节将第一次走进Python的语言之旅,将会介绍条件与循环.本节我们将会涉及到复合语句,简要介绍一下Python的语法规则是有必要的Python语法规则 1.语句 ... 
- Python基础系列----语法、数据类型、变量、编码
		1.基本语法 Python ... 
随机推荐
- django源码分析——处理请求到wsgi及视图view
			本文环境python3.5.2,django1.10.x系列 根据前上一篇runserver的博文,已经分析了本地调试服务器的大致流程,现在我们来分析一下当runserver运行起来后,django框 ... 
- 数据库SQL---范式
			1.数据冗余导致的问题:冗余存储.更新异常.插入异常.删除异常. 2.函数依赖:一种完整性约束. 在关系模式r(R)中,α属于R,β属于R. 1)α函数确定β(β函数依赖于α):记作α→β,对于任意合 ... 
- 不可错过的java面试博客之java集合篇
			1. List List 是有序的 Collection.Java List 一共三个实现类: 分别是 ArrayList.Vector 和 LinkedList ArrayList ArrayLis ... 
- python http server handle json
			用Python实现一个http server # python2 # coding = utf-8 from BaseHTTPServer import HTTPServer, BaseHTTPReq ... 
- 前端——Vue CLI 3.x搭建Vue项目
			一.Node安装 windows 1. Node.js (>=8.9, 推荐8.11.0+) Node官网下载 .msi 文件,按步骤下载安装即可. 安装完之后在cmd中输入 node -v,若 ... 
- G. Yash And Trees   线段树 + dfs序 + bitset
			这个是要用bitset 一个大整数的二进制 学习推荐博客 这个题目大意就是:给你n,m 还有一个序列,还有一个一棵树,有一种操作一种询问 操作是给你一个节点 把这个节点及其子节点都加上x 询问是 给你 ... 
- spring学习笔记(六)自定义spring-boot-starter(2)
			上篇文章我们主要讲了spring自动装配的原理,我们知道了springboot在启动的时候会自动去读.factories文件,在factories文件中,autoConfiguration对应的就是我 ... 
- [hdu4358]树状数组
			思路:用一个数组记录最近k次的出现位置,然后在其附近更新答案.具体见代码: #pragma comment(linker, "/STACK:10240000,10240000") ... 
- UEFI Shell --常用命令解释
			UEFI Shell解释 UEFI Shell 是一个提供用户和UEFI系统之间的接口,进入UEFI Shell可以对计算机系统进行配置 命令解释: 单独的help就可以输出所有指令,不做特殊说明,内 ... 
- node中几个路径的梳理
			大半夜睡不着... 今天用node写了返回客户端请求资源的http服务,确实发现了一些以前没注意到的问题. 第一个是在接收到请求的时候,解析完路径后,一定要判断请求的文件的后缀,以便选择对应的Cont ... 
