变量

命名规则

变量名必须是大小写英文字母、数字或下划线 _ 的组合,不能用数字开头,并且对大小写敏感

变量赋值

同一变量可以反复赋值,而且可以是不同类型的变量

i=2;
i="name";
print(i) D:\ALanzhishujia\soft\python\python.exe C:/Users/19768/PycharmProjects/PythonLearning/demo1.py
2

Python中用","连接,而JAVA用"+"连接

i = 2
print("i", 2) i 2
ublic static void main(String[] args) {
int i=2;
System.out.println("i"+2);
}
i2

注释

单行注释用 # 快捷键 ctrl+/

多行注释""" 注释 """ 或者用单引号

print函数

sep

print输出中默认是用空格分隔,可以通过sep更换

end

end控制最后每一个print结尾是怎样分隔

print(1, 2, 3, 4, 6, 7, sep="*", end='\t')
# \t表示键盘中的tab键
print(1, 2, 3, 4, 5, 6) 1*2*3*4*6*7 1 2 3 4 5 6

五大基本数据类型

整形(int)

i = 1
print(i, type(i))
# type()可以得到数据类型
1 <class 'int'>

浮点型(float)

字符串(str)

切分
str = "i love china"
str1 = str.split(" ")
# 返回一个list
print(str1) ['i', 'love', 'china']
截取
# 直接通过下标截取
print(str[0])
print(str[4])
# [a:b:c:] a起始下标 b结尾下标 c步长,不写默认为1,指多少几个单位截取一次
# 左闭右开
print(str[2:6:1])
print(str[::2])
print(str[-2]) i
v
love
ilv hn
n
长度
print(len(str))
12
替换
print(str.replace("love", "loving"))

i loving china
查找
print(str.index("i"))
0
反转
print(str[::-1])

anihc evol i
去除字符串两边的隐藏字符
# \r表示回车,将光标移到首位
# win下回车是指\n+\r
print("\n\t\rabc ")
print("\n\t\rabc ".strip()) abc
abc

布尔型(bool)

空值(none)

运算符

算数运算符

+ - * / % ** //
a = 10
b = 3
print(a + b)
print(a - b)
print(a * b)
print(a / b)
print(a % b)
# 10的三次方
print(a ** b)
# 取整,相当于java中/
print(a // b)
#先算后面,2的9次方
print(2**3**2)
print(30//7//3) 13
7
30
3.3333333333333335
1
1000
3
512
1

逻辑运算符

bool1 = 1
bool2 = 0
print(bool1 & bool2) # 0
print(bool1 and bool2) # 0
print(bool1 | bool2) # 1
print(bool1 or bool2) # 1
print(bool1 ^ bool2) # 1
print(not bool1) # Flase

类型转换

函数 int()、float()、str() 和 bool() 分别用于将变量转换 成整型、浮点型、字符串和布尔型变量

# 对于数值型,除0以外都是true
# 对于字符串,除空字符串以外都是true
print(bool("abc")) # True
print(bool("")) # False
print(bool(1)) # True
print(bool(0)) # False
print(bool(0.0)) # False
print(bool(None)) # False

数据容器

列表list []

列表(list)是一个有序的序列结构,序列中的元素可以是不同的数据类型,元素可以不唯一(可以重复)

常见用法
# 获取元素
list1 = [1, 2, 7, 4, 5]
print(list1[4]) # 5
print(list1[0:3]) # [1, 2, 7]
print(list1[::-1]) # [5, 4, 7, 2, 1]
# 增
list1.append(8)
print(list1) # [1, 2, 7, 4, 5, 8]
list1.insert(1, 1.1)
print(list1) # [1, 1.1, 2, 7, 4, 5, 8]
# 改
list1[2] = "3"
print(list1) # [1, 1.1, '3', 7, 4, 5, 8]
# 删
print(list1.pop()) # 将最后一个元素拿出来 8
list1.remove("3")
print(list1) # [1, 1.1, 7, 4, 5]
# 升序降序
list1.sort()
print(list1) # [1, 1.1, 4, 5, 7]
list1.sort(reverse=True)
print(list1) # [7, 5, 4, 1.1, 1]

元祖tuple ()

元组(tuple)数据结构与列表类 似,其中元素可以有不同的类型

但是元组中的元素是不可变的, 即一旦初始化之后,就不能够再 做修改(报错:元组对象不支持 赋值)

tuple1 = (1, 2, 3, "china", 8.7)
print(tuple1.index("china")) # 3
print(tuple1.count(2)) # 1 出现次数
print(tuple1[2]) # 3
print(tuple1[2::]) # (3, 'china', 8.7)

字典dict {}

字典是一种大小可变的键值对集,其中的键(key)和 值(value)都是Python对象

字典用在需要高速查找的地方

字典中的数据元素是无序的,并不会按照初始化的顺序排列。不同键所 对应的值可以相同,但是字典中的键必须是唯一的

dict1 = {
"k1": "v2",
78: "v2",
0: "v3",
# list1: "v4",
# True: "v5" 不能是这些
2: list1
}
print(dict1)
# 取元素
print(dict1[0])
print(dict1.get(78))
print(dict1.get(99, "不存在就返回"))
# 增
dict1["app"] = "append"
print(dict1)
# 删
dict1.pop("app")
del dict1[2]
print(dict1)
# 改
dict1["k1"] = "vvvvv2"
print(dict1) {'k1': 'v2', 78: 'v2', 0: 'v3', 2: [7, 5, 4, 1.1, 1]}
v3
v2
不存在就返回
{'k1': 'v2', 78: 'v2', 0: 'v3', 2: [7, 5, 4, 1.1, 1], 'app': 'append'}
{'k1': 'v2', 78: 'v2', 0: 'v3'}
{'k1': 'vvvvv2', 78: 'v2', 0: 'v3'}

集合set {}

集合(set)是一种无序集,它是一组键的集合,不存储值

去重。把一个列表变成集合,就自动去重了

set1 = {1, 2, 3, 3, "china", 8.5, None}
print(set1, type(set1)) # {1, 2, 3, None, 8.5, 'china'} <class 'set'>
set1.add(2) # 和append的区别就是add会自动去重 set2 = {1, 2, 3, 4, 5, 6}
set3 = {4, 5, 6, 7, 8, 9}
print(set2 & set3) # 交集 {4, 5, 6}
print(set2 | set3) # 并集 {1, 2, 3, 4, 5, 6, 7, 8, 9}
print(set2 - set3) # 差集 {1, 2, 3}
print(set3 - set2) # 差集 {8, 9, 7}

常用函数

enumerate函数

因为在遍历的时候没有下标,所有可以使用enumerate函数加下标

for i in list1:
print(i) for i in enumerate(list1):
print(i) 7
5
4
1.1
1
(0, 7)
(1, 5)
(2, 4)
(3, 1.1)
(4, 1)

zip函数

将list压缩成dict

list2 = ["k1", "k2", "k3"]
list3 = ["v1", "v2", "v3"]
for i in zip(list2,list3):
print(i) ('k1', 'v1')
('k2', 'v2')
('k3', 'v3')

格式化字符串

str_format = "{}*{}={}"
print(str_format.format(3, 5, 3 * 5)) # 3*5=15
# %d只能是整形,%s表示字符串,%3.f表示保留三位小数
print("%d*%d=%d" % (3, 5, 3 * 5)) # 3*5=15

range函数

用于生成序列,左闭右开

for i in range(1, 11, 2):
print(i) 1
3
5
7
9

列表推导式

list1 = [i for i in range(1, 11)]
print(list1)
list1 = [i for i in range(1, 11) if i % 2 == 0]
print(list1) [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
[2, 4, 6, 8, 10]

打印列表

# 这里list1内容需要为str类型
list2 = [str(i) for i in list1]
print("|".join(list2)) #2|4|6|8|10

九九乘法表

print("\n".join([("\t".join(["{}*{}={}".format(i, j, i * j) for j in range(1, i + 1)])) for i in range(1, 10)]))
# 拆开写
# print("\n".join([str(i) for i in range(1, 10)]))
# 然后把里面的str(i) 变成("\t".join(["{}*{}={}".format(i, j, i * j) for j in range(1, i + 1)]))

Python语法1的更多相关文章

  1. 对 Python 语法不够了解导致的 bug

    对 Python 语法不够了解导致的 bug. `in` '20' in '11264,6144,4096,3072,2048,1024,300,30' Out[7]: True a_list = ' ...

  2. python 笔记2:python语法基础

    python语法学习笔记: 1 输入输出 input(),print(). name = input('input your name : ')print('hello ,'+name)print(& ...

  3. python语法快速入门(1)

    http://www.runoob.com/python/python-tutorial.html Python 是一种解释型语言: 这意味着开发过程中没有了编译这个环节.类似于PHP和Perl语言 ...

  4. python语法笔记(四)

    1.对象的属性     python一切皆对象,每个对象都可能有多个属性.python的属性有一套统一的管理方案. 属性的__dict__系统     对象的属性可能来自于其类定义,叫做类属性:还可能 ...

  5. python语法-[with来自动释放对象]

    python语法-[with来自动释放对象] http://www.cnblogs.com/itech/archive/2011/01/13/1934779.html 一 with python中的w ...

  6. wxpython 支持python语法高亮的自定义文本框控件的代码

    在研发闲暇时间,把开发过程中比较重要的一些代码做个珍藏,下面的代码内容是关于wxpython 支持python语法高亮的自定义文本框控件的代码,应该是对大家也有用. import keywordimp ...

  7. Python语法的转义字符

    Python语法的转义字符 转义字符 说 明 \ 续行符 \n 换行符 \0 空  \t 水平制表符,用于横向跳到下一制表位 \'' 双引号 \' 单引号 \\ 一个反斜杠 \f 换页 \0dd 八进 ...

  8. Python语法教程总结规范

    Python语法易错点记录 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分享. ...

  9. 初试Python语法小试牛刀之冒泡排序

    Python很火,心里很慌,没吃过猪肉,也要见见猪走路. 看了几天Python的语法,大概初步了解了一点点,https://www.liaoxuefeng.com/wiki/0014316089557 ...

  10. (数据分析)第02章 Python语法基础,IPython和Jupyter Notebooks.md

    第2章 Python语法基础,IPython和Jupyter Notebooks 当我在2011年和2012年写作本书的第一版时,可用的学习Python数据分析的资源很少.这部分上是一个鸡和蛋的问题: ...

随机推荐

  1. 路由懒加载---Vue Router

    一.什么是懒加载? 懒加载也就是延迟加载或者按需加载,即在需要的时候进行加载. 二.为什么在Vue路由中使用懒加载? 像vue这种单页面应用,如果没有应用懒加载,运用webpack打包后的文件将会异常 ...

  2. STM32F103C8T6使用SPI接口驱动WS2812b灯条

    之前一篇文章写了使用IO控制WS2812b操作原理,但是由于IO的输出比较慢,所以现在改用了硬件SPI控制WS2812b灯条 把SPI的mosi线接到ws2812b的数据线,SPI的速率可达十几Mbi ...

  3. selenium用css、xpath表达式进行元素定位

    绝对路径选择 从根节点开始的,到某个节点,每层都依次写下来,每层之间用 / 分隔的表达式,就是某元素的 绝对路径 Xpath : /html/body/div CSS : html>body&g ...

  4. Jmeter系列(15)- 常用断言之大小断言

    大小断言 大小断言验证响应数据size大小,它的作用范围有主Sample与子Sample:适用场景,判断附件下载的大小,比如项目安装包 完整响应:全部响应信息 响应头:响应头信息,比如http协议的头 ...

  5. Park-2018论文

    太阳射电图:Solar magnetograms, EUV images, GOES X-ray flux data. Magnetograms:    http://solar-center.sta ...

  6. ubuntu系统执行生成密匙命令后,home目录下面没有生成.ssh目录

    ubuntu系统配置git ssh时,执行:ssh-keygen -trsa -C "youremail@example.com",home目录下面没有生成.ssh目录. .ssh ...

  7. Centos7.6安装python3.6.8

    yum -y install bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel libffi-devel tk-devel ...

  8. 搞定 NodeJS 开发调试

    代码调试有时候是一种充满挑战的工作,如果有一个趁手的调试工具的话,往往可以做到事半功倍的效果.得益于这些年的快速发展,在 NodeJS 生态中已经有了多种调试工具可以使用.我们今年就来分享几个常用的调 ...

  9. 🧚‍♂️全套Java教程_Java基础入门教程,零基础小白自学Java必备教程👨‍💻004 # 第四单元 流程控制语句上 #

    一.本单元知识点概述 二.本单元目标 (Ⅰ)重点知识目标 1.if语句的格式及执行流程2.switch语句的格式及执行流程 (Ⅱ)能力目标 1.掌握if语句的格式及执行流程2.掌握switch语句的格 ...

  10. kubeadm 命令简介

    kubeadm 命令 kubeadm init 启动一个kubernetes主节点 kubeadm join 启动一个kubernetes工作节点并加入到集群中 kubeadm upgrade 更新一 ...