python全栈学习--day1
计算机基础
CPU:中央处理器
内存:4GB,8GB,临时处理事务的地方,供给CPU数据。
硬盘:相当于电脑的数据库,存储着大量的数据,文件,电影等。
操作系统:执行者,支配所有关系
windows,linux,Unix,AIX 等
2.python是什么编程语言。
编程语言主要从以下几个角度为进行分类,编译型和解释型、静态语言和动态语言、强类型定义语言和弱类型定义语言,每个分类代表什么意思呢,我们一起来看一下。
2.1 编译型与解释型。
编译器是把源程序的每一条语句都编译成机器语言,并保存成二进制文件,这样运行时计算机可以直接以机器语言来运行此程序,速度很快;
而解释器则是只在执行程序时,才一条一条的解释成机器语言给计算机来执行,所以运行速度是不如编译后的程序运行的快的.
这是因为计算机不能直接认识并执行我们写的语句,它只能认识机器语言(是二进制的形式)
编译型
优点:编译器一般会有预编译的过程对代码进行优化。因为编译只做一次,运行时不需要编译,所以编译型语言的程序执行效率高。可以脱离语言环境独立运行。
缺点:编译之后如果需要修改就需要整个模块重新编译。编译的时候根据对应的运行环境生成机器码,不同的操作系统之间移植就会有问题,需要根据运行的操作系统环境编译不同的可执行文件。
解释型
优点:有良好的平台兼容性,在任何环境中都可以运行,前提是安装了解释器(虚拟机)。灵活,修改代码的时候直接修改就可以,可以快速部署,不用停机维护。
缺点:每次运行的时候都要解释一遍,性能上不如编译型语言。
2.2动态语言和静态语言
通常我们所说的动态语言、静态语言是指动态类型语言和静态类型语言。
(1)动态类型语言:动态类型语言是指在运行期间才去做数据类型检查的语言,也就是说,在用动态类型的语言编程时,永远也不用给任何变量指定数据类型,该语言会在你第一次赋值给变量时,在内部将数据类型记录下来。Python和Ruby就是一种典型的动态类型语言,其他的各种脚本语言如VBScript也多少属于动态类型语言。
(2)静态类型语言:静态类型语言与动态类型语言刚好相反,它的数据类型是在编译其间检查的,也就是说在写程序时要声明所有变量的数据类型,C/C++是静态类型语言的典型代表,其他的静态类型语言还有C#、JAVA等。
2.3强类型定义语言和弱类型定义语言
(1)强类型定义语言:强制数据类型定义的语言。也就是说,一旦一个变量被指定了某个数据类型,如果不经过强制转换,那么它就永远是这个数据类型了。举个例子:如果你定义了一个整型变量a,那么程序根本不可能将a当作字符串类型处理。强类型定义语言是类型安全的语言。
(2)弱类型定义语言:数据类型可以被忽略的语言。它与强类型定义语言相反, 一个变量可以赋不同数据类型的值。
强类型定义语言在速度上可能略逊色于弱类型定义语言,但是强类型定义语言带来的严谨性能够有效的避免许多错误。另外,“这门语言是不是动态语言”与“这门语言是否类型安全”之间是完全没有联系的!
例如:Python是动态语言,是强类型定义语言(类型安全的语言); VBScript是动态语言,是弱类型定义语言(类型不安全的语言); JAVA是静态语言,是强类型定义语言(类型安全的语言)。
通过上面这些介绍,我们可以得出,python是一门动态解释性的强类型定义语言。
3.python的优缺点
先看优点
- Python的定位是“优雅”、“明确”、“简单”,所以Python程序看上去总是简单易懂,初学者学Python,不但入门容易,而且将来深入下去,可以编写那些非常非常复杂的程序。
- 开发效率非常高,Python有非常强大的第三方库,基本上你想通过计算机实现任何功能,Python官方库里都有相应的模块进行支持,直接下载调用后,在基础库的基础上再进行开发,大大降低开发周期,避免重复造轮子。
- 高级语言————当你用Python语言编写程序的时候,你无需考虑诸如如何管理你的程序使用的内存一类的底层细节
- 可移植性————由于它的开源本质,Python已经被移植在许多平台上(经过改动使它能够工 作在不同平台上)。如果你小心地避免使用依赖于系统的特性,那么你的所有Python程序无需修改就几乎可以在市场上所有的系统平台上运行
- 可扩展性————如果你需要你的一段关键代码运行得更快或者希望某些算法不公开,你可以把你的部分程序用C或C++编写,然后在你的Python程序中使用它们。
- 可嵌入性————你可以把Python嵌入你的C/C++程序,从而向你的程序用户提供脚本功能。
再看缺点:
- 速度慢,Python 的运行速度相比C语言确实慢很多,跟JAVA相比也要慢一些,因此这也是很多所谓的大牛不屑于使用Python的主要原因,但其实这里所指的运行速度慢在大多数情况下用户是无法直接感知到的,必须借助测试工具才能体现出来,比如你用C运一个程序花了0.01s,用Python是0.1s,这样C语言直接比Python快了10倍,算是非常夸张了,但是你是无法直接通过肉眼感知的,因为一个正常人所能感知的时间最小单位是0.15-0.4s左右,哈哈。其实在大多数情况下Python已经完全可以满足你对程序速度的要求,除非你要写对速度要求极高的搜索引擎等,这种情况下,当然还是建议你用C去实现的。
- 代码不能加密,因为PYTHON是解释性语言,它的源码都是以名文形式存放的,不过我不认为这算是一个缺点,如果你的项目要求源代码必须是加密的,那你一开始就不应该用Python来去实现。
- 线程不能利用多CPU问题,这是Python被人诟病最多的一个缺点,GIL即全局解释器锁(Global Interpreter Lock),是计算机程序设计语言解释器用于同步线程的工具,使得任何时刻仅有一个线程在执行,Python的线程是操作系统的原生线程。在Linux上为pthread,在Windows上为Win thread,完全由操作系统调度线程的执行。一个python解释器进程内有一条主线程,以及多条用户程序的执行线程。即使在多核CPU平台上,由于GIL的存在,所以禁止多线程的并行执行。关于这个问题的折衷解决方法,我们在以后线程和进程章节里再进行详细探讨。
当我们编写Python代码时,我们得到的是一个包含Python代码的以.py
为扩展名的文本文件。要运行代码,就需要Python解释器去执行.py
文件。
由于整个Python语言从规范到解释器都是开源的,所以理论上,只要水平够高,任何人都可以编写Python解释器来执行Python代码(当然难度很大)。事实上,确实存在多种Python解释器。
4.python历史
pytho崇尚优美,清晰,简单,是一个优秀并广泛的语言。
python2x,ptyhon3x,区别。
python2x:源码混乱,重复代码较多,冗余。
python3x:源码规范,崇尚优美清晰,简单。
5.python的分类
解释型:当程序运行时,将代码一行一行的解释成二进制,再运行。
优点:排错快,开发效率高,跨平台。
缺点:执行效率底。
典型:C。
编译型:
将代码一次性全部编译成一次性全部编译成二进制,然后在运行。
缺点:排错慢,开发效率低,不能跨平台。
优点:执行效率高。
6.python的优缺点
7.python的版本
8.运行第一个python程序
- t1.py
- print('hell0, ketty')
区别:
python2x: print() 或者 print '内容'
python3x print('内容')
python 2x 默认编码:ascii
python 3x 编码: utf-8
解决方式:在首行 # -*- encoding:utf-8 -*-
9.变量
1.变量必须有数字,字母,下划线任意组合。
2.变量不能以数字开头。
3.变量不能是python中的关键字。
以下关键字不能声明为变量名
- ['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'exec', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'print', 'raise', 'return', 'try', 'while', 'with', 'yield']
4.变量的定义要具有可描述性。
5.变量不能是中文。
6.变量不能太长。
7.官方推荐:
#驼峰体
AgeOfOldboy = 56
NumberOfStudents = 80
#下划线
age_of_oldboy = 56
number_of_students = 80
- #数字类型
- i = 100
- print(1 * 3)
- #字符串类型
- #在python种被引号引起来的数据就是字符串。
- name = '老男孩'
- name2 = '路飞学院'
- print(name,name2)
- #单双引号的配合使用
- msg = "my name is Alex , I'm 22 years old !!!"
- #多引号的配合使用
- name3 = '''
- 今天我想写首小诗,
- 歌颂我的同桌,
- 你看他那只乌黑的短发,
- 好像一只炸鸡。
- '''
- print(name3)
- #字符串:+与字符串+ * 与数字乘
- #字符串的拼接
- n1 = '老男孩'
- n2 = ' 最好的培训机构'
- n3 = n1 + n2
- print(n3)
- #字符串的相乘
- i = '坚强'
- print(i*8)
- 重点:字符串只能相加或者相乘
- #bool值 True False
- print(1 > 2 and 3 < 4 or 4 > 5)
- print(1,type)
10.常量
不变的量:如 生日,身份证号,
python 规定没有,默认全部大写的变量 成为常量。
BIRTH = 1996.10.9
11.注释
为什么有注释?
帮助你记起来之前的代码,或者帮助别人看懂你的代码。
单行注释:#
多行注释:''' '''或者""" ""
12.基础数据类型初始
1. 整数类型 int #用于计算
type() 判断此数据
2. 长整型 long
3. 浮点型 fat
4. 字符串类型 str
5.python简单的加减乘除法
- print(1+2+3=4)
- print(1+2+3+4)*3 + 5)
- print((((1+2+3+4)*3 + 5) + 100) /3)
- x = 1+2+3+4
- y = x * 3 + 5
13.用户交互
input 字符串数据类型
python2x: raw_input()
python3x: input()
14.IF语句
#第一种结构
- if 3 > 2:
- print(666):
#第二种结构
if 条件:
结果
else:
结果
- if 3 > 2:
- print(666)
- else:
- print(333)
重点:一个=号是赋值,两个==号是比较。数字之间只能比较大小.
int -->str str(123) #数字换换为整型字符串
str -->int int(123) #字符串转换为数字
#第三种结构:
- choice = input('请输入你的猜的数字:')
- if choice == '':
- print('请你吃饭')
- elif choice == '':
- print('免你一周的作业')
- elif choice == '':
- print('一起去玩')
- else:
- print('选择错误...')
15.while语句
- while True:
- print(111)
- print(222)
注意:以上运行会是死循环。重点:字符串只能比较大小
如何跳出循环,改变条件
#标志位
flag = True
while flag:
print()
break 跳出条件
continue 结束本次循环
- flag = True
- while flag:
- print('痒')
- print('凉凉')
- print('体面')
- print('社会摇')
- flag = False
- #只是第一次使用count为1
- flag = True
- count = 1
- while flag :
- print(count)
- count = count + 1
- if count == 101:
- flag = False
- #第二种方式count为条件
- count = 1
- while count < 101:
- print(count)
- count = count + 1
- #以break为条件
- while True:
- print(111)
- print(222)
- break
- print(333)'''
- #以continue为条件
- while True:
- print(111)
- print(222)
- continue
- #练习题 1
#使用while循环输入 1 2 3 4 5 6 8 9 10
#方法一:
- count = 0
while count <= 9:
count += 1
if count > 6 and count < 8:
continue
print("本次循环执行数目",count)
print('--------out of while loop---------')
- #方法二:
- count = 0
while count <= 9:
count += 1
if count == 7:
continue
print(count)
- #练习题 2
- count = 1
- sum = 0
- while True:
- sum = sum + count
- print(sum)
- if count == 100:
- break
- count += 1
- print(count)
- ###第二种办法
- count = 1
- sum = 0
- while count < 101:
- sum = sum + count
- count += 1
- print(sum)
- #第三种办法
count = 0 #初始值
while count < 99: #设定最大数值
count += 1 #自增
if count % 2 == 1: #取余
print(count) #打印
- #练习题 3
#输出 1-100 内的所有奇数- count = 0
- while count < 100:
- count += 1
- if count % 2 == 1:
- print(count)
- #练习题 4
- #输出 1-100 内的所有偶数
- count = 0
- while count < 100:
- count += 1
- if count % 2 == 0:
- print(count)
- #练习题 5
#求1-2+3-4+5 ... 99的所有数的和
#初始值- count = 0
- #总和的初始值
- num = 0
- while count < 100:
- count = count + 1
- #print(count)
- yushu = count % 2
- if yushu == 1:
- #print(count)
- num = num - count
- print(num)
- else:
- num = num + count
- print(num)
- #练习题 6
- #用户登陆(三次机会重试)
- count = 0
- name = 'john'
- password = '123'
- while True:
- if count == 3:
- print('你已经输错三次了!')
- break
- usernames = input('请输入用户名:')
- passwords = input('请输入密码:')
- if usernames == name and passwords == password:
- print('恭喜你,登录成功!')
- break
- else:
- count += 1
- print('输入错误')
- ###方法二:
- count = 1
name='hjh'
passwd='123'
while count <= 3: #这里设置小于等于3次,也就是只循环3次
count += 1 #这里为设置初始值自增。默认是 1,没循环一遍加一。
username = input('请输入用户:')
password = input('请输入密码:')
if username == name and password == passwd:
print('登录成功!')
break #这里设置break 是为了防止重复登录,也可以设置跳转或者链接到其他地址,暂时没学习。还不会
else:
print('登录失败!')
python全栈学习--day1的更多相关文章
- python全栈学习路线
python全栈学习路线-查询笔记 查询目录 一,硬件 十一,数据 ...
- python全栈学习--day4
列表 说明:列表是python中的基础数据类型之一,它是以[]括起来,每个元素以逗号隔开,而且他里面可以存放各种数据类型比如: 1 li = ['alex',123,Ture,(1,2,3,'wu ...
- python全栈学习--day3
一.基础数据类型 基础数据类型,有7种类型,存在即合理. 1.int 整数 主要是做运算的 .比如加减乘除,幂,取余 + - * / ** %...2.bool 布尔值 判断真假以及作为条件变量3. ...
- python全栈学习--day2
一.in的使用 说明:in有相当多的用处,比如判断,循环for 等. 实例一:in 操作符用于判断关键字是否存在于变量中 s = '男人john' print('男孩' in s) print('男孩 ...
- Python全栈学习_day002知识点
今日大纲: . while循环 . 格式化输出 . 运算符 . 编码初识 1. while循环 - while 无限循环: while True: # 死循环 print('大悲咒') print(' ...
- Python全栈学习_day001作业
Day1作业及默写 1.简述变量命名规范 1. 必须以字母.数字.下划线命名,且不能以数字开头 2. 不能是python的关键字 3. 不能以中文或者拼音作为变量名 4. 命名格式推荐以驼峰式或者下划 ...
- python全栈学习--day11(函数高级应用)
一,函数名是什么? 函数名是函数的名字,本质:变量,特殊的变量. 函数名()执行此函数 ''' 在函数的执行(调用)时:打散. *可迭代对象(str,tuple,list,dict(key))每一个元 ...
- python全栈学习--day10(函数进阶)
一,引言 现在我有个问题,函数里面的变量,在函数外面能直接引用么? def func1(): m = 1 print(m) print(m) #这行报的错 报错了:NameError: name 'm ...
- python全栈学习--day9(函数初始)
Python 函数 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但你也 ...
随机推荐
- 芝麻HTTP:Gerapy的安装
Gerapy是一个Scrapy分布式管理模块,本节就来介绍一下它的安装方式. 1. 相关链接 GitHub:https://github.com/Gerapy 2. pip安装 这里推荐使用pip安装 ...
- RHEL部署ipa红帽身份验证
1.先下载必须包 yum install -y ipa-server bind bind-dyndb-ldap 2.初始化ipa基本配置 ipa-server-install * Configure ...
- Acperience HDU - 5734
Deep neural networks (DNN) have shown significant improvements in several application domains includ ...
- C#图解教程 第二十四章 反射和特性
反射和特性 元数据和反射Type 类获取Type对象什么是特性应用特性预定义的保留的特性 Obsolete(废弃)特性Conditional特性调用者信息特性DebuggerStepThrough 特 ...
- 如何通过java反射的方式对java私有方法进行单元测试
待测试的私有方法: import org.testng.Assert;import org.testng.annotations.BeforeClass;import org.testng.annot ...
- 【BZOJ2342】双倍回文(回文树)
[BZOJ2342]双倍回文(回文树) 题面 BZOJ 题解 构建出回文树之后 在\(fail\)树上进行\(dp\) 如果一个点代表的回文串长度为\(4\)的倍数 并且存在长度为它的一半的回文后缀 ...
- [BZOJ1607] [Usaco2008 Dec] Patting Heads 轻拍牛头 (数学)
Description 今天是贝茜的生日,为了庆祝自己的生日,贝茜邀你来玩一个游戏. 贝茜让N(1≤N≤100000)头奶牛坐成一个圈.除了1号与N号奶牛外,i号奶牛与i-l号和i+l号奶牛相邻.N号 ...
- MySQL配置文件
[mysqld]datadir=/usr/local//mysql/data #数据存放位置socket=/var/lib/mysql/mysql.sockuser=mysqllower_cas ...
- 在开启kerberos 后,hbase存在数据命名空间的问题(解决方案)
用hbase的超级用户 su - hbasekinit -kt /etc/security/keytabs/hbase.headless.keytab hbase-bigdata@STARYEA.CO ...
- 解决JSON.stringify()自动将中文转译成unicode的方法
最近在工作中,发现在IE8下JSON.stringify()自动将中文转译为unicode编码,原本选择的中文字符,传到后台变为了unicode编码,即\u****的形式.查找资料后发现,与标准的JS ...