Python基础知识汇总
1.执行脚本的两种方式
Python a.py 直接调用Python解释器执行文件
chomd +x a.py ./a.py #修改a.py文件的属性,为可执行,在用 ./ 执行a.py 文件
2、简述位、字节的关系
1bytes=8bit ,2**8=256,可以代表256中变化,
3、简述 ascii、unicode、utf-8、gbk 的关系
ascii 是最早美国用的标准信息交换码,把所有的字母的大小写,各种符号用 二进制来表示,共有256中,加入些拉丁文等字符,1bytes代表一个字符,
Unicode是为了统一世界各国语言的不用,统一用2个bytes代表一个字符,可以表达2**16=65556个,称为万国语言,特点:速度快,但浪费空间,
可以用在内存处理中,兼容了utf-8,gbk,ASCII,
utf-8 为了改变Unicode的这种缺点,规定1个英文字符用1个字节表示,1个中文字符用3个字节表示,特点;节省空间,速度慢,用在硬盘数据传输,网络数据传输,相比硬盘和网络速度,体现不出来的,
gbk 是中文的字符编码,用2个字节代表一个字符,
4、请写出 “李杰” 分别用 utf-8 和 gbk 编码所占的位数
utf-8 是3 bytes=24bit
gbk 是2bytes=16bit
5、Pyhton 单行注释和多行注释分别用什么?
单行注释 #
多行注释 """ """三个双引号或是三个单 引号把要解释的内容放中间, ‘’‘ ’’’
6、声明变量注意事项有那些?
万能避错规则,以小写字母开头命名,可以加上下划线,或者数字,
不能以Python的关键字命名,
能表明变量的意义
8、如何查看变量在内存中的地址?
z=1
print(id(z))
9、执行 Python 程序时,自动生成的 .pyc 文件的作用是什么?
.pyc 是编译py文件后的二进制文件,用于加速运行
10、写代码
a.实现用户输入用户名和密码,当用户名为 seven 且 密码为 123 时,显示登陆成功,否则登陆失败!
name=input('name:').strip()
pwd=input('pwd:').strip()
if name=='seven' and pwd=='123' :
print('ok')
else:
print('error')
b.实现用户输入用户名和密码,当用户名为 seven 且 密码为 123 时,显示登陆成功,否则登陆失败,失败时允许重复输入三次
while循环:
count=1
while count<=3 :
name = input('name:').strip()
pwd = input('pwd:').strip() if name=='seven' and pwd=='123' :
print('ok')
else:
print('error')
count += 1
for循环:
for count in range(3) :
name = input('name:').strip()
pwd = input('pwd:').strip() if name=='seven' and pwd=='123' :
print('ok')
else:
print('error')
count += 1
c.实现用户输入用户名和密码,当用户名为 seven 或 alex 且 密码为 123 时,显示登陆成功,否则登陆失败,失败时允许重复输入三次
while 循环
count =1
while count<=3 :
name = input('name: ')
pwd = input('pwd: ')
if name == 'seven' and pwd == '123' or name == 'alex' and pwd == '123':
print('ok')
else :
print('error')
count+=1
for循环
for count in range(3) :
name = input('name: ')
pwd = input('pwd: ')
if name == 'seven' and pwd == '123' or name == 'alex' and pwd == '123':
print('ok')
else :
print('error')
count+=1
11、写代码
a. 使用while循环实现输出2-3+4-5+6...+100 的和
count=2
num=0
while count<=100 :
if count % 2 ==0 :
num=count+num
count+=1
else:
num=num-count
count+=1
print(num) b. 使用for循环和range实现输出 1-2+3-4+5-6...+99 的和
num=0
count=1
for count in range(100) :
if count % 2 == 0 :
num=num - count
else :
num=num+count
print(num)
c. 使用 while 循环实现输出 1,2,3,4,5, 7,8,9, 11,12
count=1
while count < 13 :
if count !=6 :
if count !=10 :
print(count) count+=1
d. 使用 while 循环实现输出 1-100 内的所有奇数
for i in range(101) :
if i %2 != 0 :
print(i)
count=0
while count<100 :
if count %2 != 0 :
print(count)
count += 1
e. 使用 while 循环实现输出 1-100 内的所有偶数
for i in range(100) :
if i %2 == 0:
print(i)
count=0
while count<100 :
if count%2 == 0 :
print(count)
count+=1
12、分别书写数字 5,10,32,7 的二进制表示
print(bin(5))二进制 0b101
print(hex(10))十六进制 0x5
print(oct(5)) 八进制 0o5
14、现有如下两个变量,请简述 n1 和 n2 是什么关系? n1 = 123 n2 = 123
n1,n2是连个不同的变量名,但值都一样,都指向了同一个内存地址,
16、现有如下两个变量,请简述 n1 和 n2 是什么关系? n1 = 123456 n2 = n1
n2赋值给n1.指向同一个内存地址,
17、如有一下变量 n1 = 5,请使用 int 的提供的方法,得到该变量最少可以用多少个二进制位表示?
n1=5
print(int.bit_length(n1)) 结果 3
18、布尔值分别有什么?
False .Ture ,或1 和0
20、写代码,有如下变量,请按照要求实现每个功能 name = " aleX"
a. 移除 name 变量对应的值两边的空格,并输入移除有的内容
print(name.strip())
b. 判断 name 变量对应的值是否以 "al" 开头,并输出结果
print(name.startswith('al'))
c. 判断 name 变量对应的值是否以 "X" 结尾,并输出结果
print(name.endswith('x'))
d. 将 name 变量对应的值中的 “l” 替换为 “p”,并输出结果
print(name.replace('l','p')) apex
e. 将 name 变量对应的值根据 “l” 分割,并输出结果。
print(name.split('e')) ['al', 'x '] 列表
g. 将 name 变量对应的值变大写,并输出结果
print(name.upper()) print(name.lower())
i. 请输出 name 变量对应的值的第 2 个字符?
print(name[1])
j. 请输出 name 变量对应的值的前 3 个字符?
print(name[:3])
k. 请输出 name 变量对应的值的后 2 个字符?
l. 请输出 name 变量对应的值中 “e” 所在索引位置?
print(name.index('e'))
21、字符串是否可迭代?如可以请使用 for 循环每一个元素?
依赖索引
name = "Alex "
for i in range(len(name)) :
print(name[i])
for i in name:
print(i)
22、请用代码实现:利用下划线将列表的每一个元素拼接成字符串,li = ['alex', 'eric', 'rain']
print('_'.join(['alex', 'eric', 'rain'])) alex_eric_rain
22、写代码,有如下列表,按照要求实现每一个功能 li = ['alex', 'eric', 'rain']
li = ['alex', 'eric', 'rain']
print(len(li))
b. 列表中追加元素 “seven”,并输出添加后的列表
li.append('seven')
print(li)
['alex', 'eric', 'rain', 'seven']
c. 请在列表的第 1 个位置插入元素 “Tony”,并输出添加后的列表
li.insert(0,'TONY')
print(li)
d. 请修改列表第 2 个位置的元素为 “Kelly”,并输出修改后的列表
li[1]=('killy')
print(li)
e. 请删除列表中的元素 “eric”,并输出修改后的列表
li = ['alex', 'eric', 'rain']
li.pop(1)
print(li) ['alex', 'rain']
指名道姓的删除
li = ['alex', 'eric', 'rain']
li.remove('alex')
print(li)
f. 请删除列表中的第 2 个元素,并输出删除的元素的值和删除元素后的列表
li = ['alex', 'eric', 'rain']
print(li.pop(1))
print(li) eric
['alex', 'rain']
h. 请删除列表中的第 2 至 4 个元素,并输出删除元素后的列表
li = ['alex', 'eric', 'rain']
del li[1:]
print(li)
k. 请使用 enumrate 输出列表元素和序号(序号从 100 开始)
li = ['alex', 'eric', 'rain']
for k,v in enumerate(li,1):
print(k,v)
23、写代码,有如下列表,请按照功能要求实现每一个功能 li = ["hello", 'seven', ["mon", ["h", "kelly"], 'all'], 123, 446]
a. 请输出 “Kelly”
li = ["hello", 'seven', ["mon", ["h", "kelly"], 'all'], 123, 446]
print(li[2][1][1])
b. 请使用索引找到 'all' 元素并将其修改为 “ALL”
li[2][2]='ALL'
print(li)
24、写代码,有如下元组,按照要求实现每一个功能 tu = ('alex', 'eric', 'rain')
a. 计算元组长度并输出
tu = ('alex', 'eric', 'rain')
print(len(tu))
b. 获取元组的第 2 个元素,并输出
print(tu[1])
e. 请使用 for、len、range 输出元组的索引
for i in range(len(tu)) :
print(tu.index(tu[i]))
f. 请使用 enumrate 输出元祖元素和序号(序号从 10 开始)
for k,v in enumerate(tu,10) :
print(k,v)
10 alex
11 eric
12 rain
for k in enumerate(tu,10) :
print(k)
(10, 'alex')
(11, 'eric')
(12, 'rain') 25、有如下变量,请实现要求的功能
tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11,22,33)}, 44])
c. 请问 tu 变量中的"k2"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素 “Seven”
元组,不可以
d. 请问 tu 变量中的"k3"对应的值是什么类型?是否可以被修改?如果可以,请在其中添加一个元素 “Seven”
列表,可以
tu = ("alex", [11, 22, {"k1": 'v1', "k2": ["age", "name"], "k3": (11,22,33)}, 44])
res=tu[1][2]['k2'].append('seven') print(tu)
26、字典
dic = {'k1': "v1", "k2": "v2", "k3": [11,22,33]}
for i in dic:
print(i)
b. 请循环输出所有的 value
for i in dic:
print(dic[i])
c. 请循环输出所有的 key 和 value
for i in dic:
print(i,dic[i])
d. 请在字典中添加一个键值对,"k4": "v4",输出添加后的字典
dic['k4']='v4'
print(dic)
e. 请在修改字典中 “k1” 对应的值为 “alex”,输出修改后的字典
dic['k1']='alex'
print(dic)
f. 请在 k3 对应的值中追加一个元素 44,输出修改后的字典
dic['k3'].append(44)
print(dic)
g. 请在 k3 对应的值的第 1 个位置插入个元素 18,输出修改后的字典
dic['k3'].insert(0,44)
print(dic)
27、转换
a. 将字符串 s = "alex" 转换成列表
s = "alex" print(list(s))
b. 将字符串 s = "alex" 转换成元祖
s = "alex"
print(tuple(s))
b. 将列表 li = ["alex", "seven"] 转换成元组
li = ["alex", "seven"]
print(tuple(li))
c. 将元祖 tu = ('Alex', "seven") 转换成列表
tu = ('Alex', "seven")
li=list(tu)
print(li)
d. 将列表 li = ["alex", "seven"] 转换成字典且字典的 key 按照 10 开始向后递增 dic={}
for k,v in enumerate(li,10) :----li要放在前面,序号放在后面
dic[k]=v
print(dic)
27、转码n = "老男孩"
a. 将字符串转换成 utf-8 编码的字节,并输出,然后将该字节再转换成 utf-8 编码字符串,再输出
n = "老男孩"
a=n.encode('utf-8')
print(a)
b=a.decode('utf-8')
print(b)
b. 将字符串转换成 gbk 编码的字节,并输出,然后将该字节再转换成 gbk 编码字符串,再输出
a=n.encode('gbk')
print(a)
b=a.decode('gbk')
print(b)
28、求 1-100 内的所有数的和
count=1
sum=0
for i in range(100) :
sum=sum+count
count+=1
print(sum)
count=1
sum=0
while count<=100 :
sum+=count
count+=1
print(sum)
29、元素分类
有如下值集合 [11,22,33,44,55,66,77,88,99,90],将所有大于 66 的值保存至字典的第一个 key 中,
将小于 66 的值保存至第二个 key 的值中。
即: {'k1': 大于 66 的所有值, 'k2': 小于 66 的所有值}
li=[11,22,33,44,55,66,77,88,99,90]
dic1={
'max':[],
'min':[]
}
for i in li :
if i <66 :
dic1['min'].append(i)
else:
dic1['max'].append(i)
print(dic1) ---{'max': [66, 77, 88, 99, 90], 'min': [11, 22, 33, 44, 55]} https://mp.weixin.qq.com/s/BX-_9T1vhVIlAznLibz1Bg
Python基础知识汇总的更多相关文章
- python 基础知识汇总—— if else while continue
1.if 语句 什么是if语句?if语句用来干什么的? if语句说通俗点,就是判断,如果判断条件为真,那么就执行语句,就像我们生活中例子,如果你饿了,判断为真,就要吃饭,于是你就会执行吃饭这个动作,如 ...
- Python开发【第二篇】:Python基础知识
Python基础知识 一.初识基本数据类型 类型: int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**31-2**31-1,即-2147483648-2147483647 在64位 ...
- python基础知识(二)
以下内容,作为python基础知识的补充,主要涉及基础数据类型的创建及特性,以及新数据类型Bytes类型的引入介绍
- jquery基础知识汇总
jquery基础知识汇总 一.简介 定义 jQuery创始人是美国John Resig,是优秀的Javascript框架: jQuery是一个轻量级.快速简洁的javaScript库.源码戳这 jQu ...
- python 基础知识(一)
python 基础知识(一) 一.python发展介绍 Python的创始人为Guido van Rossum.1989年圣诞节期间,在阿姆斯特丹,Guido为了打发圣诞节的无趣,决心开发一个新的脚本 ...
- python基础知识讲解——@classmethod和@staticmethod的作用
python基础知识讲解——@classmethod和@staticmethod的作用 在类的成员函数中,可以添加@classmethod和@staticmethod修饰符,这两者有一定的差异,简单来 ...
- python爬虫主要就是五个模块:爬虫启动入口模块,URL管理器存放已经爬虫的URL和待爬虫URL列表,html下载器,html解析器,html输出器 同时可以掌握到urllib2的使用、bs4(BeautifulSoup)页面解析器、re正则表达式、urlparse、python基础知识回顾(set集合操作)等相关内容。
本次python爬虫百步百科,里面详细分析了爬虫的步骤,对每一步代码都有详细的注释说明,可通过本案例掌握python爬虫的特点: 1.爬虫调度入口(crawler_main.py) # coding: ...
- python 爬虫与数据可视化--python基础知识
摘要:偶然机会接触到python语音,感觉语法简单.功能强大,刚好朋友分享了一个网课<python 爬虫与数据可视化>,于是在工作与闲暇时间学习起来,并做如下课程笔记整理,整体大概分为4个 ...
- python基础知识小结-运维笔记
接触python已有一段时间了,下面针对python基础知识的使用做一完整梳理:1)避免‘\n’等特殊字符的两种方式: a)利用转义字符‘\’ b)利用原始字符‘r’ print r'c:\now' ...
随机推荐
- select @@identity的用法 转
用select @@identity得到上一次插入记录时自动产生的ID 如果你使用存储过程的话,将非常简单,代码如下:SET @NewID=@@IDENTITY 说明: 在一条 INSERT.SELE ...
- Least Common Multiple (最小公倍数,先除再乘)
思路: 求第一个和第二个元素的最小公倍数,然后拿求得的最小公倍数和第三个元素求最小公倍数,继续下去,直到没有元素 注意:通过最大公约数求最小公倍数的时候,先除再乘,避免溢出 #include ...
- !important覆写css行内样式
<div class="block"> <span style="font-weight: bold; color: red;">Hel ...
- Leetcode872.Leaf-Similar Trees叶子相似的树
请考虑一颗二叉树上所有的叶子,这些叶子的值按从左到右的顺序排列形成一个 叶值序列 . 举个例子,如上图所示,给定一颗叶值序列为 (6, 7, 4, 9, 8) 的树. 如果有两颗二叉树的叶值序列是相同 ...
- Sublime Text3安装教程,配置教程,常用插件安装等方法
前言: sublimeText3的特点: 1.Sublime Text 是一款跨平台代码编辑器,在Linux.OS X和Windows下均可使用. 2.Sublime Text 是可扩展的,并包含大量 ...
- 删除指定节点Remove Nth Node From End of List
Given a linked list, remove the nth node from the end of list and return its head. For example, Give ...
- Directx11教程40 纹理映射(10)
原文:Directx11教程40 纹理映射(10) 本章尝试使用纹理行列式,或者说纹理数组,在ps中,使用2个纹理,最终的像素颜色,是光照颜色*纹理1采样颜色*纹理2采样颜色,主要是想达到如 ...
- python批量导出项目依赖包及批量安装的方法
在Python中我们在项目中会用到各种库,自带的自然不必再说,然而如果是三方库,则在进行项目移植时通常需要在新的环境下安装需要的三方库文件,面对较大项目中众多的三方库,可以先将项目依赖库导出到txt文 ...
- poj 3280【区间dp】
poj 3280 题意:给定一个字符串和每个字符删去和增加的代价,求使字符串变成回文串操作所需的最小代价. 题解:哇!开心!终于亲自做对了!做完这两题这个就回了.uva10739 uva 10453 ...
- 通过 FastAdmin 理解开源软件
通过 FastAdmin 理解开源软件 开源软件 ≠ 免费软件,免费是遵循其开源协议下的一个特性. 开源软件虽然免费,但服务是可以收费的,因为房子要钱. 开源的目的是为了用户更自由. 做开源每天会遇到 ...