Python笔记之a = [0]*x格式的含义及说明

 更新时间:2022年05月13日 09:21:25   作者:SkyEscape  
这篇文章主要介绍了Python笔记之a = [0]*x格式的含义及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

python a = [0]*x格式的含义

a为一个含有x个字符串的列表

例如:

import sys
a = "12352523452334"
num = len(a)
k = int(num/3)
print(k)
sub = [0]*k
for i in range(k):
    sub[i] = a[i*3:i*3+3]
    isString = isinstance(sub,list)
    print(isString)
    print(sub[i])
print(len(sub))

4
True
123
True
525
True
234
True
523
4

python使用技巧与爬过的坑

1 dict的使用

python中的字典应该是许多朋友常用的一种数据结构,其数据结构如下:

{key: value}

这里主要列几个字典使用的技巧。

1.1 dict的删改查

其实对于dict的删改查都需要用到查询,比如改,就是先查询到某个键值对,然后再做更改操作。

可能许多初学者对于字典的访问是如下几种方式:

for k, v in d.items():
    balabala
for v in d.values():
    balabala

其实这是一种特别浪费性能的操作方式,因为python中的dict是通过Hash方式来查询键的。简单来说就是查询键的时间复杂度是O ( 1 ) O(1)O(1),而查询值的时间复杂度是O ( n ) O(n)O(n)。放在代码里面来说,就是:

for k in d.keys():

这种查询方式是O ( 1 ) O(1)O(1)的时间复杂度,而:

for k, v in d.items():

或者:

for v in d.values():

是O ( n ) O(n)O(n)的时间复杂度。

所以为了节省查询时间,我们如果要对值进行操作,都是如下:

for k in d.keys():
    val = d[k]

而python三大数据结构:列表、元组、字典,就只有字典的键的查询是O ( 1 ) O(1)O(1)的时间复杂度,其余的都是O ( n ) O(n)O(n)的时间复杂度。

1.2 dict的键

既然上面已经说到了dict的键是hash查询的,所以dict的键有严格的要求,就是hashable的数据才能作为dict的键。

那么何为hashable?简单来说,就是在运行过程中不可修改的。

就比如列表就是可以修改的,因为列表可以随时进行append等操作,字典也是可以修改的,比如随时可以进行pop等操作。

那么什么是hashable的呢?常用的字符串、数字这些都可以,还有一个数据结构是hashable的,就是元组,因为元组是无法被修改的。所以当你想要存储一组数据作为键值的时候,可以考虑将这组数据转换成元组,毕竟list和dict是可以相互切换的嘛。

2 numpy

2.1 array

这是我最近编码过程中遇到的一个坑,就是array的赋值操作。我们通常的赋值操作就是:

a = b

但是对于numpy的ndarray对象,这种赋值不仅会将值赋过去,还会把内存地址赋值过去,比如如下代码:

import numpy as np
a = np.array([1, 2, 3])
print("id(a):", id(a))
b = a
print("id(b):", id(b))
print(id(a) == id(b))

输出结果如下:

id(a): 2721844244768
id(b): 2721844244768
True

也就是说,如果你只是使用a = b这种操作,那么你在对b进行操作的时候也会更改a,但是如果在某个使用场景,你需要对b进行操作,但是不改变a,那么要用如下的代码(b = a.copy()):

import numpy as np
a = np.array([1, 2, 3])
print("id(a):", id(a))
b = a.copy()
print("id(b):", id(b))
print(id(a) == id(b))

输出结果:

id(a): 1549742256336
id(b): 1549742141968
False

3 文件操作

3.1 pickle

pickle是大家常用的一个文件,最大的优点在于什么东西存储进去,就可以读取什么东西出来。

pickle是以二进制方式进行存储与读取的,比如下面的栗子:

import pickle
with open(filepath_1, 'rb') as f:
    file = pickle.load(f)
with open(filepath_2, 'wb') as f:
    pickle.dump(file, f)

但是可能有许多初学者会在写入pickle的时候选择追加方式写入(比如爬虫中断等情况),但是这种方式是不可行的。因为pickle是二进制操作,如果以追加方式写入,那么你在读取的时候只能读取到第一次写入的内容,之后的内容是无法读取的。

那么在这种有可能因为中断等原因需要一直添加内容到pkl里面,我比较推荐分成不同份的文件进行保存,既可以保证文件能够正常的读取,也不用担心因为程序中断而导致需要重新执行的问题。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Python结合Selenium简单实现Web自动化测试

    Python结合Selenium简单实现Web自动化测试

    这篇文章是入门级别的应用Python + Selenium进行自动化测试,包括环境搭建及简单的实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • pyinstaller打包程序exe踩过的坑

    pyinstaller打包程序exe踩过的坑

    这篇文章主要介绍了pyinstaller打包exe踩过的坑,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • 变长双向rnn的正确使用姿势教学

    变长双向rnn的正确使用姿势教学

    这篇文章主要介绍了变长双向rnn的正确使用姿势,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-05-05
  • Python光学仿真理解Jones矩阵学习

    Python光学仿真理解Jones矩阵学习

    这篇文章主要为大家介绍了Python光学仿真理解Jones矩阵的学习,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪
    2021-10-10
  • Python 数据库操作SQL基础

    Python 数据库操作SQL基础

    在本章节中,我们将讨论 Python 数据库操作的基础知识,重点关注 SQL即Structured Query Language,结构化查询语言,SQL 是用于管理关系型数据库的标准编程语言,可以用来执行数据定义、数据操作和数据控制等任务
    2023-06-06
  • python之NAN和INF值处理方式

    python之NAN和INF值处理方式

    这篇文章主要介绍了python之NAN和INF值处理方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • python实现小球弹跳效果

    python实现小球弹跳效果

    这篇文章主要为大家详细介绍了python实现小球弹跳效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-05-05
  • python+VTK环境搭建及第一个简单程序代码

    python+VTK环境搭建及第一个简单程序代码

    这篇文章主要介绍了python+VTK环境搭建及第一个简单程序代码,简单介绍了vtk,然后分享了安装步骤,最后涉及一个简单的代码示例,具有一定借鉴价值,需要的朋友可以参考下。
    2017-12-12
  • Python3+Selenium+Chrome实现自动填写WPS表单

    Python3+Selenium+Chrome实现自动填写WPS表单

    本文通过python3、第三方python库Selenium和谷歌浏览器Chrome,完成WPS表单的自动填写,通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-02
  • Python实现Appium端口检测与释放的实现

    Python实现Appium端口检测与释放的实现

    这篇文章主要介绍了Python实现Appium端口检测与释放的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12

最新评论