【Python基础】2万字-详解Python基础函数,包教包会_什么是python 2万字(2)

还有兄弟不知道网络安全面试可以提前刷题吗?费时一周整理的160+网络安全面试题,金九银十,做网络安全面试里的显眼包!

王岚嵚工程师面试题(附答案),只能帮兄弟们到这儿了!如果你能答对70%,找一个安全工作,问题不大。

对于有1-3年工作经验,想要跳槽的朋友来说,也是很好的温习资料!

【完整版领取方式在文末!!】

93道网络安全面试题

内容实在太多,不一一截图了

黑客学习资源推荐

最后给大家分享一份全套的网络安全学习资料,给那些想学习 网络安全的小伙伴们一点帮助!

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

😝朋友们如果有需要的话,可以联系领取~

1️⃣零基础入门
① 学习路线

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

image

② 路线对应学习视频

同时每个成长路线对应的板块都有配套的视频提供:

image-20231025112050764

2️⃣视频配套工具&国内外网安书籍、文档
① 工具

② 视频

image1

③ 书籍

image2

资源较为敏感,未展示全面,需要的最下面获取

在这里插入图片描述在这里插入图片描述

② 简历模板

在这里插入图片描述

因篇幅有限,资料较为敏感仅展示部分资料,添加上方即可获取👆

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

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

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

str.isalpha()

isalpha() 判断字符串中是否所有字符都是字母(可以为汉字),是 True ,否 False,空字符串返回 False

示例 🅰️

'Python新视野'.isalpha()

output:True

示例 🅱️

'123Python'.isalpha()

output:False

其中包含了数字,返回 False

str.isdigit()

isdigit() 判断字符串中是否所有字符都是数字(Unicode数字,byte数字(单字节),全角数字(双字节),罗马数字),是 True ,否 False,空字符串返回 False

示例 🅰️

'四123'.isdigit()

output:False

其中包含了汉字数字,返回 False

示例 🅱️

b'123'.isdigit()

output:True

byte 数字返回 True

str.isspace()

字符串中只包含空格(\n\r\f\t\v),是 True ,否 False,空字符串返回 False

符号含义
\n换行
\r回车
\f换页
\t横向制表符
\v纵向制表符
' \n\r\f\t\v'.isspace()

output:True
str.join()

join(iterable) 以指定字符串作为分隔符,将 iterable 中所有的元素(必须是字符串)合并为一个新的字符串。

','.join(['Python', 'Java', 'C'])

output:‘Python,Java,C’
str.ljust() & str.rjust()

1️⃣ ljust() 返回一个指定宽度左对齐的字符串

  • width:长度
  • fillchar:右部空余部分填充的字符,默认使用空格
ljust_str = 'Python新视野'.ljust(15, "!")
ljust_str

output:‘Python新视野!!!’

2️⃣ rjust() 返回一个指定宽度右对齐的字符串,与 ljust 操作正好相反。

  • width:长度
  • fillchar:左部空余部分填充的字符,默认使用空格
rjust_str = 'Python新视野'.rjust(15, "!")
rjust_str

output:’!!!Python新视野’
str.lower() & str.islower()

1️⃣ lower() 将指定字符串转换为小写。

lower_str = 'Python新视野'.lower()
lower_str

output:‘python新视野’

2️⃣ islower() 判断字符串所有区分大小写的字符是否都是小写形式,是 True ,否 False,空字符串或字符串中没有区分大小写的字符返回 False

'python-sun'.islower()

output:True

'python-sun' 区分大小写的字符有 'pythonsun',并且都是小写,所以返回 True

str.lstrip() & str.rstrip() & str.strip()

1️⃣ lstrip() 会在字符串左侧根据指定的字符进行截取,若未指定默认截取左侧空余(空格,\r,\n,\t等)部分。

name = '+++Python新视野+++'
name.lstrip('+')

output:‘Python新视野+++’

2️⃣ rstrip()lstrip() 用法相似,只是截取右侧的内容。

name = '+++Python新视野+++'
name.rstrip('+')

output:’+++Python新视野’

3️⃣ strip() 实际是 lstrip()rstrip() 的结合,它会截取字符串两边指定的字符。

name = '+++Python新视野+++'
name.strip('+')

output:‘Python新视野’
str.split() & str.splitlines()

1️⃣ str.split(sep=None, maxsplit=-1) 使用 sep 作为分隔符将字符串进行分割,返回字符串中的单词列表。

  • seq: 用来分割字符串的分隔符。None(默认值)表示根据任何空格进行分割,返回结果中不包含空格。
  • maxsplit: 指定最大分割次数。-1(默认值)表示不限制。
split_str = 'P y t h o n 新 视 野'
split_str.split(maxsplit=2)

output:[‘P’, ‘y’, ‘t h o n 新 视 野’]

使用默认的空格进行分割,设置最大的分割次数为2

2️⃣ str.splitlines 返回字符串中的行列表,它按照行 ('\r',\n','\r\n') 分隔,返回分隔后的列表。它只有一个参数 keepends 表示是否在结果中保留换行符,False (默认)不保留,True 保留。

示例 🅰️

split_str = 'P\ny\r t h o n 新 视 野'
split_str.splitlines()

output:[‘P’, ‘y’, ’ t h o n 新 视 野’]

示例 🅱️

split_str = 'P\ny\r t h o n 新 视 野'
split_str.splitlines(keepends=True)

output:[‘P\n’, ‘y\r’, ’ t h o n 新 视 野’]
str.startswith() & str.endswith

1️⃣ startswith(prefix[, start[, end]]) 检查字符串是否是以指定子字符串 substr 开头,是 True ,否 False,空字符串会报错。如果指定 startend ,则在指定范围内检查。

startswith_str = 'Python新视野'
startswith_str.startswith('thon', 2)

output:True

从第 3 个字符开始检测

2️⃣ str.endswith(suffix[, start[, end]])startswith 用法相同,不同之处是检查字符串是否以指定子字符串结尾,是 True ,否 False,空字符串会报错。

endswith_str = 'Python新视野'
endswith_str.endswith('thon', 0, 6)

output:True

从第 1 个字符开始检测,到第 7 个字符结束(不包含第 7 个),注意这里的范围和字符串切片其实是一样的道理,都是前闭后开。

str.title() & str.istitle()

1️⃣ title() 返回字符串中每一个单词首字母大写。

title_str = 'python新视野 python新视野'.title()
title_str

output:‘Python新视野 Python新视野’

2️⃣ istitle() 判断字符串是否满足每一个单词首字母大写,是 True ,否 False,空字符串返回 False

'Abc Def '.istitle()

output:True
str.upper() & str.isupper()

1️⃣ upper() 将指定字符串中字母转换为大写。

upper_str = 'Python新视野'.upper()
upper_str

output:‘PYTHON新视野’

2️⃣ isupper() 判断字符串所有区分大小写的字符是否都是大写形式,是 True ,否 False,空字符串或字符串中没有区分大小写的字符返回 False

'PYTHON-SUN'.isupper()

output:True

列表操作

list()

list() 将可迭代对象转成列表。

示例 🅰️

list((0,1,2)) + list({0,1,2}) + list('012')

output:[0, 1, 2, 0, 1, 2, ‘0’, ‘1’, ‘2’]

将元组、集合、字符串转换成列表并通过运算符连接。

示例 🅱️

list(range(3))

output:[0, 1, 2]

将可迭代对象转换成列表

list.append()
lst = ['Python', 'Java']
lst.append('C')
lst

output:[‘Python’, ‘Java’, ‘C’]
list.extend()

extend() 在列表的末尾添加可迭代对象(列表、元组、字典、字符串)中的元素来扩展列表。

1️⃣ 追加列表

lst = ['Python', 'Java', 'C']
lst.extend([1, 2, 3])
lst

output:[‘Python’, ‘Java’, ‘C’, 1, 2, 3]

2️⃣ 追加字符串

lst = ['Python', 'Java', 'C']
lst.extend('123')
lst

output:[‘Python’, ‘Java’, ‘C’, ‘1’, ‘2’, ‘3’]

将字符串中的每一个字符当做一个元素追加到原列表末尾

3️⃣ 追加集合

lst = ['Python', 'Java', 'C']
lst.extend({1,2,3})
lst

output:[‘Python’, ‘Java’, ‘C’, 1, 2, 3]

4️⃣ 追加字典

lst = ['Python', 'Java', 'C']
lst.extend({1: 'b', 2: 'a'})
lst

output:[‘Python’, ‘Java’, ‘C’, 1, 2]

只将字典的 key 值追加到原列表末尾

list.insert()

insert(index, object) 将指定对象插入到列表的 index 位置,原本 index 位置上及 > index 的元素的元素整体后移。

示例 🅰️

lst = ['Python', 'Java', 'C']
lst.insert(1, 'C++')
lst

output:[‘Python’, ‘C++’, ‘Java’, ‘C’]

示例 🅱️

lst = ['Python', 'Java', 'C']
lst.insert(6, 'C++')
lst

output:[‘Python’, ‘Java’, ‘C’, ‘C++’]

index 的值大于列表长度时,会在列表末尾添加。

list.pop()

pop(index=-1) 移除列表中指定位置元素(默认最后一个),并且返回移除元素的值。若指定的 index 值超过列表长度则会报错。

lst = ['Python', 'Java', 'C']
lst.pop(1), lst

output:(‘Java’, [‘Python’, ‘C’])
list.remove(元素)

lst.remove(value) 移除列表中第一次出现的 value ,无返回值,直接修改列表;如果 value 不在列表中则报错。

示例 🅰️

lst = ['Python', 'Java', 'C', 'Python']
lst.remove('Python')
lst

output:[‘Java’, ‘C’, ‘Python’]

只删除了第一次出现的 Python

示例 🅱️

lst = ['Python', 'Java', 'C', 'Python']
lst.remove('HTML')
lst

output:ValueError: list.remove(x): x not in list

HTML 不在列表中,发生错误

list.clear()

list.clear() 移除列表中所有的元素,无返回值。

lst = ['Python', 'Java', 'C']
lst.clear()
lst

output:[]
list.index()

index(value, start, stop) 返回列表中查找的第一个与value匹配的元素下标,可通过 [start, stop) 指定查找范围。

示例 🅰️

lst = ['Python', 'Java', 'C',
	   'Python', 'Python']
lst.index('Python')

output:0

不指定范围,在列表全部元素中查找

示例 🅱️

lst = ['Python', 'Java', 'C',
	   'Python', 'Python']
lst.index('Python', 1, 3)

output:ValueError: ‘Python’ is not in list

指定范围 [1, 3) ,即在[‘Java’, ‘C’]中查找 Python 很明显不存在,发生报错

list.count()

count(value) 返回 value 在列表中出现的次数。若未在列表中找到 value 则返回 0 。

示例 🅰️

lst = ['Python', 'Java', 'C',
	   'Python', 'Python']
lst.count('Python')

output:3

示例 🅱️

lst = ['Python', 'Java', 'C',
	   'Python', 'Python']
lst.count('Py')

output:0

列表中无元素 'Py',返回 0 。

list.reverse()

reverse() 将列表逆序排列,无返回值。

lst = [1, 5, 9, 2]
lst.reverse()
lst

output:[2, 9, 5, 1]
list.sort()

sort() 对列表进行指定方式的排序,修改原列表,该排序是稳定的(即两个相等元素的顺序不会因为排序而改变)。

  • key: 指定可迭代对象中的每一个元素来按照该函数进行排序
  • reverse: False 为升序,True 为降序。

示例 🅰️

lst = [1, 5, 9, 2]
lst.sort()
lst

output:[1, 2, 5, 9]

示例 🅱️

lst = ['Python', 'C', 'Java'] 
lst.sort(key=lambda x:len(x), reverse=False)
lst

output:[‘C’, ‘Java’, ‘Python’]

指定 key 计算列表中每个元素的长度,并按照长度进行升序排序

list.copy()

copy() 对列表进行拷贝,返回新生成的列表,这里的拷贝是浅拷贝,下面会说明为什么特意说它是浅拷贝

示例 🅰️

lst = [[1,2,3], 'a' ,'b']
lst_copy = lst.copy()
lst_copy.pop()
lst, lst_copy

output:([[1, 2, 3], ‘a’, ‘b’], [[1, 2, 3], ‘a’])

lst 进行 copy ,然后删除列表 lst_copy 的最后一个元素,此时的 lst 的最后一个元素并未被删除,说明两个列表指向的地址确实不一样。

示例 🅱️

lst = [[1,2,3], 'a' ,'b']
lst_copy = lst.copy()
lst_copy[0].pop()
lst_copy.pop()
lst, lst_copy

output:([[1, 2], ‘a’, ‘b’], [[1, 2], ‘a’, ‘b’])

这里执行和上一个示例一样的操作,只是这次再删除一个数据,即列表嵌套的子列表中最后一个元素,观察结果,发现这时不仅仅是 lst_copy 的列表发生改变,原列表 lst 中嵌套的字列表也发生了改变。说明两个列表指向的地址不一样,但子列表中指向的地址是相同的。

扩展:直接赋值、浅拷贝、深拷贝

(1)直接赋值,传递对象的引用而已。原始列表改变,被赋值的对象也会做相同改变。

(2)浅拷贝,没有拷贝子对象,所以原始数据子对象改变,拷贝的子对象也会发生变化。

(3)深拷贝,包含对象里面的子对象的拷贝,所以原始对象的改变不会造成深拷贝里任何子元素的改变,二者完全独立。

1️⃣ 先看直接赋值

lst = [1,2,3,[1,2]]
list1 = lst

# --直接赋值--
lst.append('a')
list1[3].append('b')

print(lst,'地址:',id(lst))   
print(list1,'地址:',id(list1))
# [1, 2, 3, [1, 2, 'b'], 'a'] 地址: 2112498512768
# [1, 2, 3, [1, 2, 'b'], 'a'] 地址: 2112498512768

无论 lst 还是 list1 发生改变,二者都会受到影响。

2️⃣ 浅拷贝需要用到 copy 模块,或者用 list.copy() 效果一样

from copy import copy

lst = [1, 2, 3, [1, 2]]
list2 = copy(lst)

# --浅拷贝--
lst.append('a')
list2[3].append('b')

print(lst,'地址:',id(lst))
print(list2,'地址:',id(list2))
# [1, 2, 3, [1, 2, 'b'], 'a'] 地址: 2112501949184
# [1, 2, 3, [1, 2, 'b']] 地址: 2112495897728

lstlist2 地址不同,但子列表的地址仍是相同的,修改子列表中的元素时,二者都会受到影响。

3️⃣ 深拷贝需要用到 copy 模块中的 deepcopy ,此时两个列表完全独立。

from copy import deepcopy

lst = [1, 2, 3, [1, 2]]
list3 = deepcopy(lst)

# --深拷贝--
lst.append('a')
list3[3].append('b')

print(lst,'地址:',id(lst))
print(list3,'地址:',id(list3))
# [1, 2, 3, [1, 2], 'a'] 地址: 2112506144192
# [1, 2, 3, [1, 2, 'b']] 地址: 2112499460224

根据结果可以看到修改子列表中的值时,原列表未发生改变。


元组

tuple()

tuple() 将可迭代对象转换成元组。

tuple([0,1,2]) + tuple(range(3)) + tuple({0,1,2}) + tuple('012')

output:(0, 1, 2, 0, 1, 2, 0, 1, 2, ‘0’, ‘1’, ‘2’)

将可迭代对象转换成列表并通过运算符连接。


字典

dict.clear()

clear() 清除字典的所有内容。

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.clear()
dic

output:{}
dict.fromkeys()

fromkeys() 创建一个新字典,以序列 iterable 中元素做字典的键,value 为字典所有键对应的初始值。

  • iterable: 可迭代对象,新字典的键。
  • value: 可选参数, 设置键序列对应的值,默认为 None
dict.fromkeys(['CSDN', '公众号'],
              'Python新视野')

output:{‘CSDN’: ‘Python新视野’, ‘公众号’: ‘Python新视野’}
dict.get()

get(key, default=None) 根据指定的 key 值查找,如果 key 在字典中,则返回 key 的值,否则为 None

示例 🅰️

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.get('CSDN')

output:‘Dream丶killer’

示例 🅱️

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
print(dic.get('微信'))

output:None

字典中没有 key 等于 '微信',返回 None,jupyter notebook 对于 None 如果不加 print 默认不输出,所以这里加上print 来打印结果

dict.items()

items() 返回视图对象,是一个可遍历的 key/value 对,可以使用 list() 将其转换为列表。

示例 🅰️

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
list(dic.items())

output:[(‘CSDN’, ‘Dream丶killer’), (‘公众号’, ‘Python新视野’)]

示例 🅱️

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
for key, value in dic.items():
    print('key: ', key, 'value: ', value)

# key: CSDN value: Dream丶killer
# key: 公众号 value: Python新视野

dict.keys()

keys() 返回一个视图对象,值为字典的 key ,可将其转换成列表。

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.keys()

output:dict_keys([‘CSDN’, ‘公众号’])
dict.setdefault()

setdefault(key, default=None) 如果键不在字典中,则插入值为 None 的键。如果键在字典中,则返回键的值。

示例 🅰️

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.setdefault('CSDN', 'python-sun')

output:‘Dream丶killer’

字典中有 CSDN 这个 key 值,返回 CSDN 对应的值,不需要插入

示例 🅱️

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.setdefault('微信', 'python-sun')
dic

output:{‘CSDN’: ‘Dream丶killer’, ‘公众号’: ‘Python新视野’, ‘微信’: ‘python-sun’}

字典中没有 微信 这个 key 值,返回 None ,执行插入,并根据设置的参数 python-sun 来进行赋值。

dict.update()

dict.update(dict1) 把字典 dict1key/value 对更新到 dict 里,当 dict1key 出现在 dict 中则修改 dict 中的值,如果 key 没有出现在 dict 中,则添加这一对 key/value

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic1 = {'CSDN': 'new\_name',
        '微信': 'python-sun'}
dic.update(dic1)
dic

output:{‘CSDN’: ‘new_name’, ‘公众号’: ‘Python新视野’, ‘微信’: ‘python-sun’}
dict.values()

values() 返回一个视图对象,值为字典的 value ,可将其转换成列表。

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.values()

output:dict_values([‘Dream丶killer’, ‘Python新视野’])
dict.pop()

pop() 删除指定 keykey/value ,如果 key 没有找到,则报错。

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.pop('CSDN')
dic

output:{‘公众号’: ‘Python新视野’}
dict.popitem()

popitem() 删除字典中末尾的元素,并返回一个元组的(键,值)对。字典为空则报错。

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.popitem()

output:(‘公众号’, ‘Python新视野’)

集合

set.add()

向集合中添加一个元素,但如果该元素已经出现在集合中,则不起作用。

示例 🅰️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set1.add('python')
set1

output:{‘Dream丶Killer’, ‘Python新视野’, ‘python’, ‘python-sun’}

示例 🅱️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set1.add('python-sun')
set1

output:{‘Dream丶Killer’, ‘Python新视野’, ‘python-sun’}

添加的元素 python-sun 已经出现在集合中,所以 set1 不发生变化

set.clear()

clear() 移除集合中的所有元素。

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set1.clear()
set1

output:set()
set.difference() & set.difference_update()

1️⃣ difference() 返回多个集合的差集,通俗来讲就是返回第一个 set 中哪些元素没有在其他 set 中出现。

示例 🅰️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python', 'Dream丶Killer'}
set3 = {'Python新视野'}
set1.difference(set2, set3)

output:{‘python-sun’}

set1 中的元素只有 python-sun 没有在 set2set3 中出现过,所以以及集合的形式返回 {'python-sun'}

示例 🅱️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python', 'Dream丶Killer'}
set3 = {'Python新视野', 'python-sun'}
set1.difference(set2, set3)

output:set()

set1 中的元素都在 set2set3 中出现过,所以返回空集合 set()

2️⃣ difference_update() 方法与 difference() 方法的区别在于 difference() 方法返回一个移除相同元素的新集合,而 difference_update() 方法是直接移除原集合中的元素,无返回值。

示例 🅰️



### 给大家的福利


**零基础入门**


对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。


![](https://img-blog.csdnimg.cn/img_convert/95608e9062782d28f4f04f821405d99a.png)


同时每个成长路线对应的板块都有配套的视频提供:


![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/a91b9e8100834e9291cfcf1695d8cd42.png#pic_center)


因篇幅有限,仅展示部分资料


网络安全面试题


![](https://img-blog.csdnimg.cn/img_convert/80674985176a4889f7bb130756893764.png)


绿盟护网行动


![](https://img-blog.csdnimg.cn/img_convert/9f3395407120bb0e1b5bf17bb6b6c743.png)


还有大家最喜欢的黑客技术


![](https://img-blog.csdnimg.cn/img_convert/5912337446dee53639406fead3d3f03c.jpeg)


**网络安全源码合集+工具包**


![](https://img-blog.csdnimg.cn/img_convert/5072ce807750c7ec721c2501c29cb7d5.png)


![](https://img-blog.csdnimg.cn/img_convert/4a5f4281817dc4613353c120c9543810.png)

**所有资料共282G**,朋友们如果有需要全套《网络安全入门+黑客进阶学习资源包》,可以扫描下方二维码领取(如遇扫码问题,可以在评论区留言领取哦)~




**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化资料的朋友,可以点击这里获取](https://bbs.csdn.net/forums/4f45ff00ff254613a03fab5e56a57acb)**


**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值