首页 > 编程问答 >从Python列表中提取值

从Python列表中提取值

时间:2024-07-25 16:50:09浏览次数:9  
标签:python

代码图片

我只想从 .dat 文件中提取单个值,到目前为止,我已经成功提取了我想要的值,但我将各个字符串添加在一起。它非常笨重,所以寻找一种更平滑的方法,它只会给我行中的第一个值(-300)。

谢谢

代码:

        current_dir = os.getcwd()
        work_dir = "\workDir"
        PATH2WRK = os.path.join(current_dir + work_dir)
        file_name = "gpList.dat"
        PATH2GPLIST = PATH2WRK + "\\" + file_name

        Global_List = open(PATH2GPLIST, "r")
        GL = Global_List.readlines()
        newQ_ = GL[-1].split('\t')
        print(newQ_)
        newq = newQ_[0]
        print(newq)
        newQ = str(newq[0]) + str(newq[1]) + str(newq[2]) + 
             str(newq[3])
        print(newQ)

输出:

print(newQ_) = [ '-300 0.004834754\n']

打印(newq) = -300 0.004834754

打印(newQ) = -300


不需要遍历字符串来获取第一个数字,可以使用 split() 函数的强大功能来实现。以下是如何改进代码的方法:

import os

current_dir = os.getcwd()
work_dir = "\workDir"
PATH2WRK = os.path.join(current_dir + work_dir)
file_name = "gpList.dat"
PATH2GPLIST = PATH2WRK + "\\" + file_name

Global_List = open(PATH2GPLIST, "r")
GL = Global_List.readlines()
newQ_ = GL[-1].split('\t')[0]  # 直接获取第一个值
newQ = int(newQ_)  # 将字符串转换为整数
print(newQ) 

解释:

  1. GL[-1].split('\t')[0] : 这部分代码完成所有繁重的工作。
  2. GL[-1] 获取列表 GL 中的最后一行。
  3. .split('\t') 按制表符 ( \t ) 分割该行,生成一个字符串列表。
  4. [0] 选择结果列表中的第一个元素,即想要的数字。

  5. int(newQ_) : 此代码将提取的字符串转换为整数,这可能是希望对该值执行的操作。

通过此更改,的代码将变得更加简洁高效。无需进行不必要的字符串操作。

标签:python
From: 78792207

相关文章

  • 如何从另一个 python 文件运行一个 python 文件
    我正在尝试从另一个python运行一个python文件,但是当涉及到调用另一个python文件中的方法时,它只会重新运行当前的python文件。我尝试了这段代码。我将导入放入log_user_in方法中,因为如果我将其导入到文件顶部,则会出现循环导入错误。这是我的代码片段fromtkinter......
  • 如何在Mac电脑上安装Python 2
    Python是一种高级编程语言,广泛应用于数据科学、网络开发、人工智能等领域。本文将介绍如何在Mac电脑上安装Python2,帮助初学者快速入门。一、下载Python2安装包在Python官网上下载Python2的安装包,网址为https://www.python.org/downloads/release/python-2718/ 。下载完......
  • 我的 python 抓取数据是空的,不确定我的代码出了什么问题
    我的结果是空的,不确定我的代码出了什么问题:这里是我的代码:#尝试从该网站获取数据https://www.watsons.com.sg/health/c/2100000?currentPage=1importrequestsfrombs4importBeautifulSoupimportpandasaspd#Settingdisplayoptionsforpandaspd.......
  • Chrome 浏览器更新后,我的 python tagui 代码工作不稳定。问题的解决方法是什么
    我编写了一个pythontagui脚本来在chrome中操作Intranet网页。它运行良好。但是在chrome浏览器更新后,脚本每次都会在某个时刻随机停止,并且也不会抛出错误。请帮忙。我尝试重新启动电脑,但这并没有解决问题。Chrome浏览器更新后,TagUI脚本工作不稳定的问题可能由以......
  • 如何从另一个文件运行 python 文件
    我正在尝试从另一个名为LoginOrReg的文件运行一个名为HabitTracker的python文件,但是当我这样做时,它会重新运行LoginOrReg文件。我已经尝试过这个classLoginOrReg:def__init__(self,db,cursor,login_username,data):self.db=mysql.connector.......
  • Python的字典和集合
    一、字典1.定义字典字典和列表虽然类似,但是字典是无序的可变序列,并且可以像查字典一样去查找。字典的元素都是成对出现的,每个元素都是由冒号“:”和键值对(“:”左边的称为键或者Key,“:”右边的称为值或者Value)构成的,用“{}”标识,元素之间用逗号“‘,”分隔。字典的键必须是唯一......
  • 在Python中字典是如何通过哈希表实现的以及哈希冲突是如何解决的
    哈希表(散列表)的工作原理哈希表是一种使用哈希函数组织数据,以支持快速插入和搜索的数据结构。它通过哈希函数将输入的键(key)映射到表中的一个位置(即索引或槽位),从而以接近常数时间复杂度进行查找、插入和删除操作。哈希表的基本工作流程如下:哈希函数:哈希函数接受一个输入(键),并......
  • python cobs协议编解码算法demo
    1.SummaryCOBS(ConsistentOverheadByteStuffing)是一种算法,直译为一致的开销字节填充。简而言之,无论数据包的内容如何,都能通过产生高效可靠明确的数据包帧,从而使接受端能够从损坏的包中恢复。通常使用0x00来作为数据包的分隔符,即切割数据包的片分隔符。当使用0x00作为......
  • 如何将unicode编码为字节,以便可以检索到原始字符串?在Python 3.11中
    在python3.11中,我们可以对字符串进行编码,如:string.encode('ascii','backslashreplace')这对于说:hellö=>hell\\xf6但是当我插入时hellöw\\xf6rldIgethell\\xf6w\\xf6rld(注意第二个有一个看起来像字符转义序列的文字部分)......
  • python flask允许跨域
    flask接口支持跨域设置方法在Flask中,可以通过安装flask-cors扩展来支持跨域请求。下面是使用flask-cors扩展的示例代码:fromflaskimportFlaskfromflask_corsimportCORS#ipinstallflask-corsapp=Flask(__name__)CORS(app)可以通过CORS扩展的origins参数......