两个csv进行根据相同字段进行合并

news2024/9/29 17:27:05

源文件,第一列,编号0

目标文件, 编号3

根据社区名称进行匹配,然后将第一个csv文件的经纬度添加到第二个文件中。

import csv

source = r"D:\000datasets\链家房价数据\2020去重后社区名称地理编码.csv"
target = r"D:\000datasets\链家房价数据\链家网深圳二手房数据-2020.04.03 .csv"
# 打开源 CSV 文件并读取数据
with open(source, 'r',encoding='utf-8') as source_file:
    source_reader = csv.reader(source_file)
    source_data = list(source_reader)

# 打开目标 CSV 文件并读取数据
with open(target, 'r',encoding='utf-8') as target_file:
    target_reader = csv.reader(target_file)
    target_data = list(target_reader)

# 确定匹配字段的索引位置
match_field_index_source = 0
match_field_index_target = 3

# 在目标 CSV 文件中查找匹配的行,并复制字段的值
for source_row in source_data:
    match_value = source_row[match_field_index_source]

    for target_row in target_data:
        if target_row[match_field_index_target] == match_value:
            # 复制字段的值到目标文件
            target_row.append(source_row[1])
            target_row.append(source_row[2])

# 保存修改后的目标 CSV 文件
with open('target.csv', 'w', newline='',encoding='utf-8') as target_file:
    target_writer = csv.writer(target_file)
    target_writer.writerows(target_data)

使用chatgpt生成的。

如果你想将一个 CSV 文件的字段复制到另一个文件中,可以按照以下步骤进行操作:

1. 首先,使用 Python 的 `csv` 模块读取源 CSV 文件和目标 CSV 文件的数据。

import csv

# 打开源 CSV 文件并读取数据
with open('source.csv', 'r') as source_file:
    source_reader = csv.reader(source_file)
    source_data = list(source_reader)

# 打开目标 CSV 文件并读取数据
with open('target.csv', 'r') as target_file:
    target_reader = csv.reader(target_file)
    target_data = list(target_reader)

2. 确定源 CSV 文件和目标 CSV 文件中用于匹配的字段所在的索引位置。

假设源 CSV 文件和目标 CSV 文件中的匹配字段是第二列(索引位置为 1),你可以使用以下代码获取这些字段的位置:

# 确定匹配字段的索引位置
match_field_index_source = 1
match_field_index_target = 1

请根据实际情况调整索引位置。

3. 使用循环遍历源 CSV 文件的每一行,在目标 CSV 文件中查找匹配的行,并将相应字段的值复制到目标文件中。

# 在目标 CSV 文件中查找匹配的行,并复制字段的值
for source_row in source_data:
    match_value = source_row[match_field_index_source]

    for target_row in target_data:
        if target_row[match_field_index_target] == match_value:
            # 复制字段的值到目标文件
            target_row.append(source_row[field_index_to_copy])

# 保存修改后的目标 CSV 文件
with open('target.csv', 'w', newline='') as target_file:
    target_writer = csv.writer(target_file)
    target_writer.writerows(target_data)

在上述代码中,我们首先遍历源 CSV 文件的每一行,并提取用于匹配的字段值 `match_value`。

然后,我们在目标 CSV 文件中进行遍历,查找与 `match_value` 匹配的行。如果找到匹配的行,则将源 CSV 文件中要复制的字段值 `source_row[field_index_to_copy]` 添加到目标文件的当前行中。

最后,使用 `csv.writer()` 和 `writerows()` 方法将修改后的目标数据写入目标 CSV 文件。

请根据实际情况调整字段的索引位置和要复制的字段索引。确保源文件和目标文件的字段名称以及数据格式是相同的。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/804233.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

TAURI桌面平台制作应用程序工具包初体验

原文:https://tauri.app/zh-cn/v1/guides/getting-started/setup/html-css-js 前提:https://tauri.app/zh-cn/v1/guides/getting-started/prerequisites 步骤1: 在 D:\MyStudy\TauriDemo 文件夹下新建 ui 文件夹,在 ui 文件夹中…

QChart笔记5:Polar Chart极坐标用法

QChart还有专门画极坐标的类QPolarChart&#xff0c;它的界面是一个圆盘。 #include <QApplication> #include <QDebug> #include <QtCharts/QScatterSeries> #include <QtCharts/QLineSeries> #include <QtCharts/QPolarChart> #include <Q…

HR:“抱歉不合适!”,竟是没有满足这项硬性要求?

兼容性测试主要通过人工或自动化的方式&#xff0c;在需要覆盖的终端设备上进行功能用例执行&#xff0c;查看软件性能、稳定性等是否正常。 对于需要覆盖的终端设备&#xff0c;大型互联网公司&#xff0c;像 BAT&#xff0c;基本都有自己的测试实验室&#xff0c;拥有大量终…

资深测试总结,自动化测试-ddt数据驱动yaml文件实战(详细)

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 ddt 驱动 yaml/ym…

matplotlib从起点出发(5)_Tutorial_5_sytleSheets

1 使用样式表和rcParams自定义matplotlib 以下是自定义matplotlib的属性和默认样式的提示。 有三种方式来自定义matplotlib: 在运行时设置rcParams&#xff1b;使用样式表&#xff1b;改写matplotlibrc文件。 在运行时设置rcParams优先于样式表&#xff0c;样式表优先于matp…

用户分享|当我升级了 CloudQuery 2.2.0 后......

导读&#xff1a; 7 月 13 日&#xff0c;CloudQuery&#xff08;下文简称 CQ&#xff09; 2.2.0 版本正式发布&#xff0c;在看到官方文档对新版本的介绍后&#xff0c;马上进行安装测试。本文主要为大家介绍从 CQ 1.4.2 升级到 2.2 的考量因素、测试情况&#xff0c;分享一些…

SCO 267,1656261-09-4,是一种变构GPR40全激动剂

资料编辑|陕西新研博美生物科技有限公司小编MISSwu 产品结构式&#xff1a; ​ 产品规格&#xff1a; SCO-267 1.CAS号&#xff1a;1656261-09-4 2.分子式&#xff1a;C36H46N4O5 3.分子量&#xff1a;614.79 4.包装规格&#xff1a;1g、5g、10g&#xff0c;包装灵活 5.外观颜…

【图像分类】CNN + Transformer 结合系列.1

介绍三篇结合使用CNNTransformer进行学习的论文&#xff1a;CvT&#xff08;ICCV2021&#xff09;&#xff0c;Mobile-Former&#xff08;CVPR2022&#xff09;&#xff0c;SegNetr&#xff08;arXiv2307&#xff09;. CvT: Introducing Convolutions to Vision Transformers, …

ping命令

上图为IA ping B的过程&#xff0c;在此过程中&#xff1a; 包传送在x位置时&#xff0c;DestMacB左&#xff0c;SourceMacMac_A&#xff0c;Dest ipIp_B,Src_ipIp_A包传送在y位置时&#xff0c;DestMacB右&#xff0c;SourceMacB左 &#xff0c; Dest ipIp_B,Src_ipIp_A MAC…

想学Python高级编程?这个技巧你不能错过!

前言 熟悉Python的朋友都知道&#xff0c;Python有一个让人又爱又恨的特点&#xff1a;数据类型的定义和使用非常的灵活。 在编写一个简易脚本的时候&#xff0c;这个特点让编程难度显著下降&#xff1b;但如果你需要编写一个大型程序&#xff0c;而且还需要多人协作时&#…

电磁波定义、特性以及信道相关知识

文章目录 前言一、电磁波的定义、特性、波谱1、电磁波的特性2、电磁波谱的划分及用途 二、地球大气层的结构三、电磁波的传播方式1、地波&#xff08;ground-wave&#xff09;2、天波&#xff08;sky-wave&#xff09;3、视线传播&#xff08;line-of-sight&#xff09;①、相关…

Spread for Winform 16.2.20231.0 (SP2) Crack

Spread for Winform 16.2.20231.0 (SP2)发布。此版本包含针对客户报告的问题的重要修复&#xff1a; 安装版本 16 后&#xff0c;FarPoint.Localization.dll 将丢失。 将数据绑定到 Spread 时会出现 InvalidOperationException。 通过 Spread Designer 设置的上标将不会保留。…

视频加密的两种常见的方式数字版权管理和加密算法与应用

视频加密的两种常见的方式数字版权管理和加密算法与应用实例&#xff1a; 数字版权管理&#xff08;DRM&#xff09;对视频做加密处理。 数字版权管理是指使用数字版权管理技术对视频内容进行加密和保护。这可以通过给视频文件添加特殊的加密标识符、许可证或者限制访问的方式…

SpringBoot——整合Redis

简单介绍 redis是一款key-velue存储结构的内存级NoSQL数据库 - 支持多种数存储格式- 支持持久化- 支持集群 简单理解成一个大Map&#xff0c;反正我就是这么理解的。当然他的内部有很多复杂的数据类型和操作&#xff0c;咱们在这里就不过多赘述了。 安装并简单的使用Redis …

JVM-类加载

1.了解冯诺依曼计算机结构 1.1计算机处理数据过程 (1)提取阶段:由输入设备把原始数据或信息输入给计算机存储器存起来 (2)解码阶段:根据CPU的指令集架构(ISA)定义将数值解译为指令 (3)执行阶段:再由控制器把需要处理或计算的数据调入运算器 (4)最终阶段:由输出设备把最后运…

postgresql13远程连接报错 Connection to 117.50.184.237:5432 refused. Check that the hostname and port are c

报错信息 Connection to hostname:port refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections. Connection refused: no further information 解决方案 修开配置文件 vim /var/lib/pgsql/13/data/postgresql.conf…

二叉树某个节点的深度

微信公众号&#xff1a;码云成化 关注可了解更多的教程及进阶技巧。问题或建议&#xff0c;请公众号留言;如果你觉得阿云对你有所帮助&#xff0c;欢迎赞赏 深度的定义 [ 当前结点的层数。默认叶子节点是 null 节点&#xff0c;深度是 0 。其子节点是 null 节点&#xff0c;深…

JAVA基础-多线程入门(详解)

目录 引言 一&#xff0c;线程概念 二&#xff0c;创建线程 2.1&#xff0c;继承Thread类&#xff0c;重写run方法 2.2&#xff0c;实现Runnable接口&#xff0c;重写run方法&#xff0c;实现Runnable接口的实现类的实例对象作为Thread构造函 数的target 2.3&#xff0c;通…

【Vuvuzela 声音去噪算法】基于流行的频谱减法技术的声音去噪算法研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

C# SourceGenerator 源生成器初探

简介 注意&#xff1a; 坑极多。而且截至2023年&#xff0c;这个东西仅仅是半成品 利用SourceGenerator可以在编译结束前生成一些代码参与编译&#xff0c;比如编译时反射之类的&#xff0c;还有模板代码生成都很好用。 演示仓库传送门-Github-yueh0607 使用 1. 创建项目 …