Python之 __name__ ,__file__ , __doc__ 变量

目录

写在前面

1、典型的Python文件结构:

2、Python中的__name__举例

3、python中的导入举例

4、__file__ 、__doc__的用法

5、__name__好处:避免黑客攻击

5.1、 正常执行:

5.2、黑客攻击:从外表访问我们的程序


写在前面

        Python使用缩进对齐组织代码的执行,所有没有缩进的代码,都会在载入时自动执行。每个文件(模块)都可以任意写一些没有缩进的代码,并在载入时自动执行。为了区分 主执行代码和被调用文件,Python引入了变量:__name__。

1)当文件是被调用时,__name__的值为模块名;

2)当文件被执行时,__name__的值为 ‘__main__’。

基于此特性,为测试驱动开发提供了很好的支持,我们可以在每个模块中写上测试代码,这些测试代码仅当模块被Python直接执行时才会运行,代码和测试完美的结合在一起。


1、典型的Python文件结构:


2、Python中的__name__举例

__name__ : 是否为主文件

#hello.py  
def sayHello():  
    str="hello"  
    print(str);  
  
if __name__ == "__main__":  
    print ('This is main of module "hello.py"')  
    sayHello()  
      
​

        python作为一种脚本语言,我们用python写的各个module都可以包含以上那么一个类似c中的main函数,只不过python中的这种__main__与c中有一些区别,主要体现在:

1、当单独执行该module时,比如单独执行上面的hello.py程序: python hello.py,则输出

This is main of module "hello.py"  
hello  
​

    可以理解为"if __name__=="__main__":" 这一句与c中的main()函数所表述的是一致的,即作为入口;

2、当该module被其它module 引入使用时

        其中的"if __name__=="__main__":"所表示的Block不会被执行,这是因为此时module被其它module引用时,其__name__的值将发生变化,__name__的值将会是module的名字。比如在python shell中import hello后,查看hello.__name__:

>>> import hello  
>>> hello.__name__  
'hello'  
>>>   
​

3、在python中,当一个module作为整体被执行时,moduel.__name__的值是"__main__";

当一个module被其它module引用时,module.__name__将是module自己的名字;

当然一个module被其它module引用时,其本身并不需要一个可执行的入口main了。

3、python中的导入举例

注意:单独执行任何一个文件时,输出都是 :__main__

            通过文件被导入执行时,输出是: 模块名.文件名

           通过文件导入执行时,导入语句根据两个文件是否在一个文件夹(模块)下,有所不同

        from 模块名 import 文件名       或      from  文件名  import  方法名

4、__file__ 、__doc__的用法

__file__ :当前文件路径

__doc__ : 当前文件描述

5、__name__好处:避免黑客攻击

当有黑客攻击(即从外部我们的程序)时,使用__name__可防止自己的程序被黑客执行修改

5.1、 正常执行:

5.2、黑客攻击:从外表访问我们的程序

优化一下下面的代码def FileUploads_modelform(request): """ 批量上传文件 方法三:采用modelform上传,超级简单,只需要实例化表单的时候 接收一下表单里边字符串数据和文件,然后利用表单的save()方法保存一下数据即可 :param request: :return: """ # 判断提交方式GET 或POST if request.method == 'POST': File_ModelForm = FileUpload_ModelForm(request.POST, request.FILES) # 实例化FileUploadForm表单,注意获取数据的方式 if File_ModelForm.is_valid(): # file = File_ModelForm.cleaned_data['file'] # 对于文件,自动保存 # 字段+上传路径自动保存到数据库 # file_form = File_ModelForm.save() # 保存表单到数据库 # 多属性保存 Upload_File = File_ModelForm.save(commit=False) # Upload_File.file_url = Upload_File.file_url.temporary_file_path() # 文件路径 # 调用get_optimized_file_type函数获取优化文件类型 # optimized_file_type = get_optimized_file_type(Upload_File.file_url) Upload_File.file_name = Upload_File.file_url.name # 文件名 Upload_File.file_size = Upload_File.file_url.size # 文件大小 Upload_File.file_update_author = request.user.realname # 获取文件类型 # Get the file content type uploaded_file_type, encoding = mimetypes.guess_type(Upload_File.file_url.path) Upload_File.file_type = uploaded_file_type # Upload_File.file_type = Upload_File.file_url.content_type # optimized_file_type = get_optimized_file_type(file_url) Upload_File.save() # 其他操作,例如返回成功页面或其他处理 # return render(request, 'zadmin/pages/File_Uploads.html', {'file_form': file_form}) return HttpResponse("文件上传成功!") else: file_form = FileUpload_ModelForm() return render(request, 'zadmin/pages/File_Uploads.html', {'file_form': file_form})
07-15
下面是优化后的代码,我主要进行了以下改进: 1. 使用适当的命名规范,将函数名从 `FileUploads_modelform` 改为 `file_upload_modelform`。 2. 移除了不必要的注释。 3. 使用更具描述性的变量名。 4. 在文件上传之前,检查用户是否已经登录,并使用 `@login_required` 装饰器进行验证。 5. 使用 `get_optimized_file_type` 函数获取文件类型,并将其保存到数据库中。 6. 通过使用 `try-except` 块来处理可能的异常情况。 7. 返回适当的 HTTP 响应。 ```python from django.shortcuts import render, HttpResponse from .forms import FileUploadModelForm from .utils import get_optimized_file_type import mimetypes @login_required def file_upload_modelform(request): if request.method == 'POST': form = FileUploadModelForm(request.POST, request.FILES) if form.is_valid(): try: uploaded_file = form.save(commit=False) uploaded_file.file_name = uploaded_file.file_url.name uploaded_file.file_size = uploaded_file.file_url.size uploaded_file.file_update_author = request.user.realname uploaded_file_type, encoding = mimetypes.guess_type(uploaded_file.file_url.path) uploaded_file.file_type = uploaded_file_type optimized_file_type = get_optimized_file_type(uploaded_file.file_url.path) uploaded_file.optimized_file_type = optimized_file_type uploaded_file.save() return HttpResponse("文件上传成功!") except Exception as e: return HttpResponse("文件上传失败:" + str(e)) else: form = FileUploadModelForm() return render(request, 'zadmin/pages/File_Uploads.html', {'form': form}) ``` 请确保在你的Django应用程序中正确导入 `FileUploadModelForm` 和 `get_optimized_file_type` 函数,并根据你的实际需求进行适当的调整。 希望这个优化后的代码对你有帮助!如果还有其他问题,请随时提问。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值