2024年最新Python大数据之Python基础【六】变量

8、局部变量和全局变量

  • 局部变量就是在函数体内部进行定义函数体外部无法调用的变量
  • 全局变量就是在函数体外部,一般在文件顶格处书写,函数体内外都可以使用的变量
  • if 和for结构中的控制语句中定义的变量都是全局变量
# 全局变量就是在函数体外部书写的一般要在文件内顶格书写,在函数体内部外部都可以调用的变量
a = 1
b = 2


def sum1():
    # 函数体内部可以使用
    print(a + b)


sum1()
# 函数体外部也可以使用
print(a)
print(b)

# for 循环中, if 分支中创建的变量是全局变量还是局部变量呢? 全局变量
# for i in range(10):
# pass
#
# print(i)
#
# if True:
# c = 1
# print(c)

9、gloal

  • global能声明我们当前使用的变量是全局变量
  • LEGB原则
    • L:在函数体内部查找
    • E:在外层函数中查找
    • G:在全局变量中查找
    • B:在内置变量中查找
# global 全局 :作用就是声明我要使用的这个变量是全局变量

# 如果要在函数体内修改全局变量,就要使用global
a = 100

# 此处,使用a=1相当于再函数体内定义了一个局部变量,并没有修改全局变量的值
# def func1():
# a = 1
# 如果想要在函数体内修改全局变量就要使用global
# def func1():
# global a
# a = 1
#
# func1()
# print(a)

# 扩展: 在Python中所有的变量查询遵循legb原则
# 调用变量时的查询顺序
'''
L:local :首先在函数体内部查询
E:edge :在外部函数中查询
g:global:在全局变量中查询
b:built-in:在系统内置变量中查询
'''
def func1():
    # L:我们再调用变量时,先在函数体内部查找
    a = 1
    print(a)
func1()

def out\_func():
    # E: 如果当前函数中没有此变量,我们将在外部函数中查找
    a = 2
    def in\_func():
        print(a)
    in_func()

out_func()

def func2():
    # 如果函数体内部和外部函数中都没有该变量,则去全局变量中查找
    print(a)

func2()

# 当这个函数在函数体内部,外部函数中,全局变量中都不存在时, 则去内置变量中查找
print(__name__) # \_\_main\_\_


def func3():
    # a = a + 10
    # 首先用a + 10 进行计算,根据legb原则先从函数体内部查找,查找后发现a 在函数体内部定义,但是在调用时未定义则报错
    # a += 10
    # print(a)
    a = 1

def func4():
    # SyntaxError: name 'a' is assigned to before global declaration
    # 如果要对全局变量进行修改,则先对变量进行global修饰,在修改,否则报错
    a = 15
    # global a
func4()
print(a)

# 能否在函数体内部创建全局变量 可以 只要用global修饰即可
def func5():
    global num1
    num1 = 105

func5()
print(num1)

10、函数参数进阶

  • 位置参数:直接书写参数名,在传值时顺序传值,调用时既不能多传参,也不能少传参(形参)
  • 关键字参数:使用”参数名 = 值“的形式进行传参(实参)
    • 可以不按顺序赋值
    • 必须在顺序赋值之后完成赋值
  • 缺省参数:在定义函数时,给参数一个默认值,如果调用时,不给其传参,则使用默认值,如果传参,则使用传入的值
# 位置参数:按照位置顺序进行赋值的参数(形参)

def func(a, b, c, d):


![img](https://img-blog.csdnimg.cn/img_convert/3f1de26992c2329b0cc4c5278128c48b.png)
![img](https://img-blog.csdnimg.cn/img_convert/ed8e058d741a5fbb0723954a290c2837.png)
![img](https://img-blog.csdnimg.cn/img_convert/2279147b716fcbb2ab78cdfabcbd9b04.png)

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

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

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**

真正体系化!**

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

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python是一种简单易用的编程语言,它有许多强大的库和工具,可以用于从网页上爬取数据。爬取网页数据是一种获取互联网上大数据的常用方法之一。 要从网页上爬取数据,我们首先需要了解目标网页的结构。通常,网页的数据是以HTML(超文本标记语言)的形式展示的,所以我们需要使用Python中的一个库来解析HTML,如BeautifulSoup或lxml。这些库可以帮助我们从HTML中提取出所需的数据。 接下来,我们需要使用Python中的一个库来发送HTTP请求,如requests库。我们可以将目标网页的URL传递给requests库的get()函数,然后得到返回的网页内容。通过分析返回的网页内容,我们可以确定要提取的数据所在的标签和属性。 一旦我们确定了要提取的数据所在的标签和属性,我们就可以使用BeautifulSoup或lxml库来提取数据。这些库提供了各种方法和函数来搜索、遍历和提取HTML标签中的数据。 在进行网页数据爬取之前,我们还需要考虑一些道德和法律问题。首先,我们应该尊重网站的使用政策,并遵守robots.txt文件中的规定。其次,我们应该避免对网站造成不必要的负载,以免给网站服务器造成过大的压力。 总结起来,Python是一种非常适合从网页上爬取数据的编程语言。通过使用HTML解析库和HTTP请求库,我们可以很容易地从网页中提取出所需的数据。当然,在进行爬取之前我们还需要注意道德和法律问题。爬取网页数据是大数据领域的一项重要技术,它可以帮助我们获取更多的信息,拓宽我们的知识面和提高工作效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值