1、有变量name = "aleX leNb" 完成如下操作:

移除name变量对应的值两边的空格,并输出处理结果

n1 = name.strip()

print(n1)

结果:aleX leNb

移除name变量左边的'al'并输出处理结果

n2 = name.lstrip('al')

print(n2)

结果:eX leNb

移除name变量右面的'Nb',并输出处理结果

n3 = name.rstrip('Nb')

print(n3)

结果:aleX le

移除name变量开头的'a'与最后的'b',并输出处理结果

n4 = name.strip('ab')

print(n4)

结果:leX leN

判断name变量是否以 "al" 开头,并输出结果

n5 = name.startswith('al')

print(n5)

结果:True

判断name变量是否以'Nb'结尾,并输出结果

n6 = name.endswith('Nb')

print(n6)

结果:True

将name变量对应的值中的 所有的'l'替换为'p',并输出结果

n7 = name.replace('l', 'p')

print(n7)

结果:apeX peNb

将name变量对应的值中的第一个'l'替换成'p',并输出结果

n8 = name.replace('l', 'p', 1)

print(n8)

结果:apeX leNb

将name变量对应的值根据 所有的'l'分割,并输出结果。

n9 = name.split('l')

print(n9)

结果:['a', 'eX ', 'eNb']

将name变量对应的值根据第一个'l'分割,并输出结果。

n10 = name.split('l', 1)

print(n10)

结果:['a', 'eX leNb']

将name变量对应的值变大写,并输出结果

n11 = name.upper()

print(n11)

结果:ALEX LENB

将name变量对应的值变小写,并输出结果

n12 = name.lower()

print(n12)

结果:alex lenb

将name变量对应的值首字母'a'大写,并输出结果

n13 = name.capitalize()

print(n13)

结果:Alex lenb

判断name变量对应的值字母'l'出现几次,并输出结果

n14 = name.count('l')

print(n14)

结果:2

判断name变量对应的值前四位'l'出现几次,并输出结果

n15 = name.count('l', 4)

print(n15)

结果:1

从name变量对应的值中找到'N'对应的索引(如果找不到则报错),并输出结果

n16 = name.index('N')

print(n16)

结果:7

从name变量对应的值中找到'N'对应的索引(如果找不到则返回-1)输出结果

n17 = name.find('N')

print(n17)

结果:7

从name变量对应的值中找到'X le'对应的索引,并输出结果

n18 = name.find('X le')

print(n18)

结果:3 #作为整体返回

请输出 name 变量对应的值的第 2 个字符?

print(name[1])

结果:l

请输出 name 变量对应的值的前 3 个字符?

print(name[:3])

结果:ale

请输出 name 变量对应的值的后 2 个字符?

print(name[-2:])

结果:Nb

请输出 name 变量对应的值中 “e” 所在索引位置?

print(name.find('e'))

print(name.find('e', 3)

#find可以进行切片

结果:2 6

2,有字符串s = '123a4b5c'

通过对li列表的切片形成新的字符串s1,s1 = ‘123’

s1 = s[:3]

通过对li列表的切片形成新的字符串s2,s2 = ‘a4b’

s2 = s[3:6]

通过对li列表的切片形成新的字符串s3,s3 = ‘1345’

s3 = s[::2]

通过对li列表的切片形成字符串s4,s4 = ‘2ab’

s4 = s[1:-2:2]

通过对li列表的切片形成字符串s5,s5 = ‘c’

s5 = s[-1]

通过对li列表的切片形成字符串s6,s6 = ‘ba2’

s6 = s[-3::-2]

3,使用while和for循环分别打印字符串s=’asdfer’中每个元素。

# while循环实现方式
s = 'asdfer'
count = 0
while count < len(s):
print(s[count])
count += 1 # for循环实现方式
s2 = 'asdfer'
for i in s2:
print(i)

4,实现一个整数加法计算器(两个数相加):

如:content = input(‘请输入内容:’) # 如用户输入:5+9或5+ 9或5 + 9,然后进行分割再进行计算。

# 实现一个整数加法计算器(两个数相加):
# 方法可以继续加上去连续操作
content = input('请输入a+b:').strip().split('+')
sum = 0
print(num)
# int转换切片的字符串的时候会自动将前面带的空格也去掉
sum = int(num[0]) + int(num[1])
print(sum) 扩展:不限两数相加,是N个数相加。
# 实现一个整数加法计算器(不限数相加):
content = input('请输入a+b+c……:').strip().split('+')
sum = 0
print(content)
# 让content中的加数和sum自动循环相加
for i in content:
sum += int(i)
print(sum)

5,计算用户输入的内容中有几个整数(以个位数为单位)。

如:content = input(‘请输入内容:’) # 如fhdal234slfh98769fjdla

# 计算用户输入的内容中有几个整数(以个位数为单位)。
num = 0
content = input('请输入由字母和数字组成的内容:').strip()
for i in content:
if i.isdigit():
num += 1
print(num)

扩展:计算用户输入的内容中有几个整数(以相连的数字为一个整数计数)。

# 计算用户输入的内容中有几个整数(以相连的数字为一个整数计数)。
content = input('请输入:').strip()
for i in content:
# 判断i不为数字类型就用空格进行替换填充,
# 注意这里最初我是用了判断是字母类型就进行空格填充,然后就出现了测试时输入特殊符号时计算错误
# 所以有个原则是尽量用(not 真)的方式来包含不是你所求的范围。
if not i.isdigit():
content = content.replace(i, ' ', 1)
# print(content)
# 替换空格之后就可以利用split进行对空切割成列表,然后用len求出列表中的元素个数就得出整数个数结果了。
print('你输入的内容中共有%s个整数。' % len(content.split()))

End

文:铁乐与猫

2018-3-21

铁乐学python_day03-作业的更多相关文章

  1. 铁乐学Python_day12_作业

    1.写函数,返回一个扑克牌列表,里面有52项,每一项是一个元组 例如:[('红心',2),('草花',2), -('黑桃','A')] def poker(): suit = ['红心', '梅花', ...

  2. 铁乐学python_day10_作业

    1.继续整理函数相关知识点,写博客. 2.写函数,接收n个数字,求这些参数数字的和.(动态传参) def sum_n(*args): sum = 0 for i in args: sum += i r ...

  3. 铁乐学python_day09_作业

    练习题 1.整理函数相关知识点,写博客 2.写函数,检查获取传入列表或元组对象的所有奇数位索引对应的元素, 并将其作为新列表返回给调用者. def odd_index(l): lis = [] for ...

  4. 铁乐学Python_day08作业

    1. 文件a.txt内容:每一行内容分别为商品名字,价钱,个数. apple 10 3 tesla 100000 1 mac 3000 2 lenovo 30000 3 chicken 10 3 通过 ...

  5. 铁乐学python_Day44_IO多路复用

    目录 IO模型介绍 阻塞IO(blocking IO) 非阻塞IO(non-blocking IO) 多路复用IO(IO multiplexing) 异步IO(Asynchronous I/O) IO ...

  6. 铁乐学python_Day43_协程

    铁乐学python_Day43_协程 引子 之前我们学习了线程.进程的概念,了解了在操作系统中进程是资源分配的最小单位,线程是CPU调度的最小单位. 按道理来说我们已经算是把cpu的利用率提高很多了. ...

  7. 铁乐学python_Day42_线程池

    铁乐学python_Day42_线程池 concurrent.futures 异步调用模块 concurrent.futures模块提供了高度封装的异步调用接口 ThreadPoolExecutor: ...

  8. 铁乐学python_Day42_线程-信号量事件条件

    铁乐学python_Day42_线程-信号量事件条件 线程中的信号量 同进程的一样,Semaphore管理一个内置的计数器, 每当调用acquire()时内置计数器-1:调用release() 时内置 ...

  9. 铁乐学python_Day42_锁和队列

    铁乐学python_Day42_锁和队列 例:多个线程抢占资源的情况 from threading import Thread import time def work(): global n tem ...

  10. 铁乐学python_Day39_多进程和multiprocess模块2

    铁乐学python_Day39_多进程和multiprocess模块2 锁 -- multiprocess.Lock (进程同步) 之前我们千方百计实现了程序的异步,让多个任务可以同时在几个进程中并发 ...

随机推荐

  1. EXCEL导出工具类及调用

    一.Excel导出工具类代码 package com.qiyuan.util; import java.io.OutputStream; import java.io.UnsupportedEncod ...

  2. 原生js实现拖动滑块验证

    拖动滑块验证是现在的网站随处可见的,各式各样的拖动法都有. 下面实现的是某宝的拖动滑块验证: <!DOCTYPE html> <html lang="en"> ...

  3. spring boot 2.0 源码分析(三)

    通过上一章的源码分析,我们知道了spring boot里面的listeners到底是什么(META-INF/spring.factories定义的资源的实例),以及它是创建和启动的,今天我们继续深入分 ...

  4. 关于拓展jQuery功能插件的写法

    有两种方法: 1.jQuery.fn.extend() 用于将一个对象的内容合并到jQuery的原型,以提供新的jQuery实例方法 例子: <span id="test"& ...

  5. elasticsearch启动错误解决

    es启动默认不能使用root用户,所以需要新创建一个用户来启动. 启动时可能出现的问题: [1]: max file descriptors [4096] for elasticsearch proc ...

  6. [IMX6]Android6.0移植和分析

    0. 知识点 中断(设备树) [IMX6]设备树分析--dts 1. 编译 Android6.0内核移植(1):分析编译日志 Android6.0内核移植(2):kernel编译内核 单独烧录kern ...

  7. split函数和merge函数

    split函数的主要功能是把一个彩色图像分割成3个通道,方便进一步的图像处理,具体说明如下: split Divides a multi-channel array into several sing ...

  8. Android 操作Sqlite

    首先要用一个类来继承SQLiteOpenHelper,并必须实现 public DatabaseHelper(Context context, String name, CursorFactory f ...

  9. 关于git远程版本库的一些问题之解决

    Part1:CentOS6.5免密码登录 修改/etc/ssh/sshd_config RSAAuthentication yesPubkeyAuthentication yesAuthorizedK ...

  10. Java JDK 配置环境变量

    使用了java也有了两年了,安装了很多次jdk都记不住安装步骤 = =,刚刚又配置了一次,码一下步骤: 1.右击"此电脑" ---> "属性" ----& ...