网络安全最新Python入门的60个基础练习(二)

while True:
    yn = input('Continue(y/n): ')
    if yn in [‘n’, ‘N’]:
        break
    print(‘running…’)



**22-while-continue**


计算 100 以内偶数之和。


continue 是跳过本次循环剩余部分,回到循环条件处。



sum100 = 0
counter = 0

while counter < 100:
    counter += 1
    # if counter % 2:
    if counter % 2 == 1:
        continue
    sum100 += counter

print(sum100)



**23-for 循环遍历数据对象**



astr = ‘hello’
alist = [10, 20, 30]
atuple = (‘bob’, ‘tom’, ‘alice’)
adict = {‘name’: ‘john’, ‘age’: 23}

for ch in astr:
    print(ch)

for i in alist:
    print(i)

for name in atuple:
    print(name)

for key in adict:
    print(‘%s: %s’ % (key, adict[key]))



**24-range 用法及数字累加**



# range(10)  # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
# >>> list(range(10))
# range(6, 11)  # [6, 7, 8, 9, 10]
# range(1, 10, 2)  # [1, 3, 5, 7, 9]
# range(10, 0, -1)  # [10, 9, 8, 7, 6, 5, 4, 3, 2, 1]
sum100 = 0

for i in range(1, 101):
    sum100 += i

print(sum100)



**25-列表实现斐波那契数列**


列表中先给定两个数字,后面的数字总是前两个数字之和。



fib = [0, 1]

for i in range(8):
    fib.append(fib[-1] + fib[-2])

print(fib)



**26-九九乘法表**



for i in range(1, 10):
    for j in range(1, i + 1):
        print(‘%s*%s=%s’ % (j, i, i * j), end=’ ')
    print()

# i=1 ->j: [1]
# i=2 ->j: [1,2]
# i=3 ->j: [1,2,3]
# 由用户指定相乘到多少
n = int(input('number: '))

for i in range(1, n + 1):
    for j in range(1, i + 1):
        print(‘%s*%s=%s’ % (j, i, i * j), end=’ ')
    print()



**27-逐步实现列表解析**



# 10+5 的结果放到列表中
[10 + 5]
# 10+5 这个表达式计算 10 次
[10 + 5 for i in range(10)]
# 10+i 的 i 来自于循环
[10 + i for i in range(10)]
[10 + i for i in range(1, 11)]
# 通过 if 过滤,满足 if 条件的才参与 10+i 的运算
[10 + i for i in range(1, 11) if i % 2 == 1]
[10 + i for i in range(1, 11) if i % 2]
# 生成 IP 地址列表
[‘192.168.1.%s’ % i for i in range(1, 255)]



**28-三局两胜的石头剪刀布**



import random

all_choices = [‘石头’, ‘剪刀’, ‘布’]
win_list = [[‘石头’, ‘剪刀’], [‘剪刀’, ‘布’], [‘布’, ‘石头’]]
prompt = “”“(0) 石头
(1) 剪刀
(2) 布
请选择 (0/1/2): “””
cwin = 0
pwin = 0

while cwin < 2 and pwin < 2:
    computer = random.choice(all_choices)
    ind = int(input(prompt))
    player = all_choices[ind]

print(“Your choice: %s, Computer’s choice: %s” % (player, computer))
    if player == computer:
        print(‘\033[32;1m 平局、033[0m’)
    elif [player, computer] in win_list:
        pwin += 1
        print(‘\033[31;1mYou WIN!!!\033[0m’)
    else:
        cwin += 1
        print(‘\033[31;1mYou LOSE!!!\033[0m’)



**29-文件对象基础操作**



# 文件操作的三个步骤:打开、读写、关闭
# cp /etc/passwd /tmp
f = open(‘/tmp/passwd’)  # 默认以 r 的方式打开纯文本文件
data = f.read()  # read() 把所有内容读取出来
print(data)
data = f.read()  # 随着读写的进行,文件指针向后移动。
# 因为第一个 f.read() 已经把文件指针移动到结尾了,所以再读就没有数据了
# 所以 data 是空字符串
f.close()

f = open(‘/tmp/passwd’)
data = f.read(4)  # 读 4 字节
f.readline()  # 读到换行符、n 结束
f.readlines()  # 把每一行数据读出来放到列表中
f.close()

################################
f = open(‘/tmp/passwd’)
for line in f:
    print(line, end=‘’)
f.close()

##############################
f = open(‘图片地址’, ‘rb’)  # 打开非文本文件要加参数 b
f.read(4096)
f.close()

##################################
f = open(‘/tmp/myfile’, ‘w’)  # 'w’打开文件,如果文件不存在则创建
f.write(‘hello world!\n’)
f.flush()  # 立即将缓存中的数据同步到磁盘
f.writelines([‘2nd line.\n’, ‘new line.\n’])
f.close()  # 关闭文件的时候,数据保存到磁盘

##############################
with open(‘/tmp/passwd’) as f:
    print(f.readline())

#########################
f = open(‘/tmp/passwd’)
f.tell()  # 查看文件指针的位置
f.readline()
f.tell()
f.seek(0, 0)  # 第一个数字是偏移量,第 2 位是数字是相对位置。
              # 相对位置 0 表示开头,1 表示当前,2 表示结尾
f.tell()
f.close()



**30-拷贝文件**


拷贝文件就是以 r 的方式打开源文件,以 w 的方式打开目标文件,将源文件数据读出后,写到目标文件。


以下是【不推荐】的方式,但是可以工作:



f1 = open(‘/bin/ls’, ‘rb’)
f2 = open(‘/root/ls’, ‘wb’)

data = f1.read()
f2.write(data)

f1.close()
f2.close()



**31-拷贝文件**


每次读取 4K,读完为止:



src_fname = ‘/bin/ls’
dst_fname = ‘/root/ls’

src_fobj = open(src_fname, ‘rb’)
dst_fobj = open(dst_fname, ‘wb’)

while True:
    data = src_fobj.read(4096)  # 每次读取 4K
    if not data:
        break
    dst_fobj.write(data)

src_fobj.close()
dst_fobj.close()



**32-位置参数**


注意:位置参数中的数字是字符形式的



import sys

print(sys.argv)  # sys.argv 是 sys 模块里的 argv 列表

# python3 position_args.py
# python3 position_args.py 10
# python3 position_args.py 10 bob



**33-函数应用-斐波那契数列**



def gen_fib(l):
    fib = [0, 1]

for i in range(l - len(fib)):
        fib.append(fib[-1] + fib[-2])

return fib  # 返回列表,不返回变量 fib

a = gen_fib(10)
print(a)
print(‘-’ * 50)
n = int(input("length: "))
print(gen_fib(n))  # 不会把变量 n 传入,是把 n 代表的值赋值给形参



**34-函数-拷贝文件**



import sys

def copy(src_fname, dst_fname):
    src_fobj = open(src_fname, ‘rb’)
    dst_fobj = open(dst_fname, ‘wb’)

while True:
        data = src_fobj.read(4096)
        if not data:
            break
        dst_fobj.write(data)

src_fobj.close()
    dst_fobj.close()

copy(sys.argv[1], sys.argv[2])
# 执行方式
# cp_func.py /etc/hosts /tmp/zhuji.txt



**35-函数-九九乘法表**



def mtable(n):
    for i in range(1, n + 1):
        for j in range(1, i + 1):
            print(‘%s*%s=%s’ % (j, i, i * j), end=’ ')
        print()

mtable(6)
mtable(9)



**36-模块基础**


每一个以 py 作为扩展名的文件都是一个模块。



star.py:
hi = ‘hello world!’

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新网络安全全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上网络安全知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以点击这里获取
62909)]
[外链图片转存中…(img-j5xhkFg9-1714816362910)]
[外链图片转存中…(img-6yIuX87P-1714816362911)]
[外链图片转存中…(img-QZutnylf-1714816362912)]
[外链图片转存中…(img-vgefk5LX-1714816362912)]
[外链图片转存中…(img-CGBjnI9W-1714816362913)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上网络安全知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化资料的朋友,可以点击这里获取

  • 30
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值