首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

合并excel的两列,为空的单元格被另一列有值的替换?

一、前言 前几天在Python铂金交流群【逆光】问了一个Pandas数据处理的问题,问题如下:请问 合并excel的两列,为空的单元格被另一列有值的替换。...【Siris】:你是说c列是a列和b列的内容拼接起来是么 【逆光】:是 【Siris】:那你其实可以直接在excel里用CONCAT函数。 【不上班能干啥!】:只在excel里操作,速度基本没啥改变。...请大神帮我瞅瞅,我打印出来有这3列啊 【瑜亮老师】:初步看了一下你这里多了.loc 【逆光】:刚开始我没写,报错信息推荐我写 【瑜亮老师】:还有就是你后面,你是想让这三列分别是无忧,0和0对吧 【逆光】...就是你要给哪一列全部赋值为相同的值,就写df['列名'] = '值'。不要加方括号,如果是数字,就不要加引号。 【逆光】:我也试过,分开也是错的· 【瑜亮老师】:哦,是这种写法被替换了。...【瑜亮老师】:3列一起就是df.loc[:, ['列1', '列', '列3'']] = ["值", 0, 0] 【不上班能干啥!】:起始这行没有报错,只是警告,因为你这样操作会影响赋值前的变量。

11910

3分钟短文:书接上回,Laravel数据库迁移的那些个小技巧

我们需要空与非空约束,默认值约束,主键约束,外键约束等等数据库所具有的特性, 这才是关系型数据库的魅力。...比如声明一个布尔类型的值,并声明默认为false: $table->boolean('confirmed')->default(false); 比如设定一个字符串类型的字段,允许为null: $table...->string('comments')->nullable(); 比如设定整型为无符号数: $table->tinyInteger('age')->unsigned(); 在给上面的 age 字段设定默认值...的迁移指令也允许我们指定某个追加的字段位于某个列之后: $table->boolean('enabled')->after('name'); 迁移状态 查看当前数据库的迁移状态,会让我们查看创建的迁移文件中哪些被应用了...写在最后 本文是对上一章所述laravel数据库迁移功能的补充。数据库迁移是一个比较大的动作, 特别是已经上线生产的应用数据库,如果非到更新迁移的地步不可,需要预期做好演练, 以应对可能的突发事故。

1.7K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    go语言面试题:主键索引和唯一索引的区别

    主键索引和唯一索引在MySQL中都是特殊的BTree索引,但两者有以下区别: 主键索引要求主键列不能为空。为了定义一个主键索引,必须先定义一个唯一性索引。...每个表只能有一个主键索引,用于标识唯一行标识符,并且可以自动添加到外键表中。 唯一索引列可以为空,但只容许具有一个空值;而主键索引则不允许任何空值。...在InnoDB存储引擎中,如果未将 PRIMARY KEY 或 UNIQUE 关键字分配给索引声明,则第一个非NULL唯一索引被用作InnoDB的主键索引。...如果将某一列设置为唯一索引,那么这一列相同的值每种只能出现一次(除NULL)。而主键索引除了唯一性属性之外,还应该满足非空属性,即主键列不能有重复的 NULL 值。...总之,主键索引是比唯一性索引更加严格限制的一种索引类型,常用于快速查找和关联操作,而唯一索引主要是为了数据表中的具有唯一性分约束列添加保证数据表数据完整性和正确性的索引,用于快速与更新操作。

    3700

    Laravel代码简洁之道和性能优化

    经过一番调研之后发现了一个堪称神器的扩展:laravel-upsert 这个 Laravel 扩展为查询构建器和 Eloquent 添加了对 INSERT & UPDATE (UPSERT) 和 INSERT...扩展的特性 安装 composer require staudenmeir/laravel-upsert:"^1.0" 用法 插入和更新 (UPSERT) 考虑这个users具有唯一username...第二个参数是唯一标识记录的列。除 SQL Server 外的所有数据库都要求这些列具有PRIMARY或UNIQUE索引。 提供要更新的列作为第三个参数(可选)。默认情况下,将更新所有列。...username', ['active']); User::insertIgnore(['username' => 'foo']); 如果模型使用时间戳,upsert()并且insertIgnore()会自动为插入的值添加时间戳...upsert()还将添加updated_at到更新的列中。

    5.8K20

    PHP 数组:索引数组与关联数组

    1、索引数组 基本使用 所谓索引数组指的是数组的键为隐式数字,并且会自动维护,就像静态语言的数组一样。...增删改查 除了像上述代码那样通过指定初始值进行数组初始化,还可以初始化一个空数组,在 PHP 中,初始化空数组时不必指定数组大小,也不必指定数据类型: $fruits = []; 然后我们可以依次往数组中追加元素...如果要获取指定索引对应的元素值,可以通过如下这种方式: $fruit = $fruits[0]; 要更新指定索引位置对应的元素值,可以通过如下方式: $fruits[2] = 'Banana'; 要删除指定索引位置对应的元素值...除了指定所有元素的键名外,还可以部分指定: $book = [ 'name' => 'Laravel精品课', 'author' => '学院君', 'publish_at' =...增删改查 关联数组的增删改查和索引数组类似,我们以 $book 为例,先初始化一个空数组: $book = []; 然后通过指定键值对来新增元素: $book['name'] = 'Laravel精品课

    5.8K20

    Laravel Eloquent 模型关联关系(下)

    ,这样做的好处是不需要指定关联模型与父模型的外键关联字段值,Eloquent 底层会自动判断并设置。...user_id' => mt_rand(1, 15)], ['content' => $faker->paragraph, 'user_id' => mt_rand(1, 15)] ]); 更新一对多所属模型外键字段...如果是要更新新创建的模型实例所属模型(父模型)的外键字段,比如以 posts 表为例,新增的记录想要更新 user_id 字段,可以这么实现: $user = User::findOrFail(1);...前提是 user_id 允许为 null,否则会抛出异常。 空对象模型 如果外键字段 user_id 允许为空的话,当我们访问 Post 模型上的 author 属性时,默认返回为 null。...这样,我们就不需要在每个地方去判断如果文章作者信息为空该如何处理了,因为这种情况下返回的也是一个正常的 User 模型实例。

    19.6K30

    Laravel 通过迁移文件定义数据表结构

    Blueprint 类为我们提供了丰富的数据表字段定义方法,通过这些方法我们完成所有与数据表字段相关的操作,包括新增字段、删除字段、修改字段、添加索引和外键等等。...构建字段额外属性 绝大部分数据表字段都有自己的属性,比如长度、是否为空、默认值、注释信息等,比如我们可以为 users 表的 name 字段设置一些额外属性,将其长度设置为 100(默认是255),并且为该字段添加注释信息...100 的字符串,该字段会插入到 name 字段后面,允许为空,注释信息是用户昵称。...('id')->on('users'); 如果你还想进一步指定外键约束(级联删除和更新,比如我们删除了 users 表中的某个 id 对应记录,那么其在文章表中对应 user_id 的所有文章会被删除...'); 注:不推荐使用外键,更不要使用外键约束功能,因为影响数据库性能,而且级联删除有可能造成非常严重的无法挽回的后果。

    2.1K21

    SQL命令 CREATE TABLE(五)

    但是,外键可以引用RowID(ID)或标识列。在任何情况下,外键引用都必须存在于被引用的表中,并且必须定义为唯一的;被引用的字段不能包含重复值或NULL。...如果指定的表没有定义主键,则外键默认为为指定的表定义的IDENTITY列。 如果指定的表既没有定义的主键,也没有定义的标识列,则外键默认为RowID。...如果指定的表未将RowID定义为PUBLIC, IRIS会发出SQLCODE-315错误。...SET NULL-删除行或更新被引用表中的键值时,将检查所有引用表,以查看是否有任何行引用要删除或更新的行。如果是,则该操作会导致引用要删除或更新的行的外键字段设置为NULL。外键字段必须允许空值。...SET DEFAULT-删除行或更新被引用表中的键值时,将检查所有引用表,以查看是否有任何行引用要删除或更新的行。如果是,则该操作会导致引用要删除或更新的行的外键字段设置为该字段的默认值。

    1.8K50

    Laravel学习记录--Model

    ) 如不指定,默认拼接规则为 表名_id,这里为stu_id relatedPivotKey:另一模型在中间表的字段(当前模型类的外键) 如不指定,默认拼接规则与foreignPivotKey一样 这里为...([ ['phone'=>3], ['phone'=>4] ]); } 更新belongsTo关联(更新关联关系所属模型外键字段)...如果要更新新创建的模型实例所属模型的外键字段,可用associate方法实现 如 phones表要更新uid字段 public function show(){ $user = Muser...,前提是uid字段允许为空,如果不允许为空会抛出异常 空对象模型 如果外键字段uid允许为空,当我们访问Phone模型上的muser属性(注意这里是属性,而不是方法)时,默认返回null,Eloquent...有时候你需要更新中间表中已经存在的记录,使用updateExistingPivot方法 该方法接受中间记录另一个的外键和一个关联数组进行更新 public function show(){

    13.6K20

    YashanDB数据完整性

    唯一约束(Unique key)在相同的列、或多个列的组合中,是否允许不同的行拥有重复的值(允许值为NULL)。主键约束(Primary key)同时满足非空约束和唯一约束。...# 非空约束默认情况下,一个表中的所有列都允许空值,使用NOT NULL约束可以指定列不允许为空值。NOT NULL约束主要用于不能缺少值的列,例如员工信息表中的姓名列。...主键列不允许为空值。...外键的值,要么匹配被引用主键或唯一键的值,要么为空。如果复合外键中存在空值列,该键的非空列不再强制要求匹配父项中的对应列。被引用键被外键所引用的表中的唯一键或主键。...UPDATE SET NULL 更新置空(UPDATE SET NULL)是指当父表更新时,对应被引用键值在子表中的所有行的外键被设置成NULL。

    5800

    玩转 PhpStorm 系列(二):导航篇

    另一种是通过快捷键,上面的菜单栏下拉框导航选项右侧已经标注了对应的快捷键,下面我们就可以快捷键为例在 Mac 系统中进行演示(Windows 操作类似,就是快捷键有差异)。...导航到类、接口、Trait 打开一个新安装的最新版 Laravel 项目,以自带的 User 类为例,要导航到这个类,可以通过快捷键 Command + O 打开导航窗口,在输入框输入 User 进行类名的全局模糊匹配...跳转到行、列 最后,在已打开的当前文件中,可以通过 Command + L 打开行列导航操作界面,输入要导航到的行号、列号即可,其中行和列通过「行号:列号」进行区分和解析: ?...列号一般不设置,默认值为 1。 在图形化 UI 界面中,通常跳转到指定行、列的需求不大,我们可以通过鼠标和触摸屏快速定位到指定位置。...汇总导航 针对类、文件、属性、方法的导航,除了通过上述方式使用各自独立的快捷键和操作界面进行导航外,在 PhpStorm 中,还可以通过 Shift + Shift 快捷键(连按两次 Shift 键)打开汇总导航操作界面

    2.2K10

    【MySQL】04_约束

    可以作用在多个列上,不与列一起,而是单独定义 列级约束与表级约束的区别 位置 支持的约束类型 是否可以起约束名 列的后面 语法都支持,但外键没有效果 不可以 所有列的下面 默认和非空不支持,其他支持 可以...唯一约束可以是某一个列的值唯一,也可以多个列组合的值唯一。 唯一性约束允许列值为空。 在创建唯一约束的时候,如果不给唯一约束命名,就默认和列名相同。...,主键约束列不允许重复,也不允许出现空值。...主键约束对应着表中的一列或者多列(复合主键) 如果是多列组合的复合主键约束,那么这些列都不允许为空值,并且组合的值不允许重复。 MySQL的主键名总是PRIMARY,就算自己命名了主键约束名也没用。...外键与级联更新适用于 单 机低并发 ,不适合 分布式 、 高并发集群 ;级联更新是强阻塞,存在数据库 更新风暴 的风险;外键影响 数据库的 插入速度 。

    2.4K20

    MySQL从删库到跑路_高级(一)——数据完整性

    B、域完整性:限制类型(数据类型),格式(通过检查约束和规则),可能值范围(通过外键约束,检查约束,默认值定义,非空约束和规则)。...B、唯一值约束:一张表可以有多个列添加唯一值约束,一直允许一条记录为空值。 实体完整性,由主键和唯一性约束来实现,确保表中记录有一列唯一标识。...主键约束相当于唯一约束与非空约束的组合,主键约束列不允许重复,也不允许出现空值;多列组合的主键约束,列都不允许为空值,并且组合的值不允许重复。...外键声明包括三个部分: A、哪个列或列组合是外键 B、指定外键参照的表和列 C、参照动作[cascade(级联操作),restrict(拒绝操作),set null(设为空),no action,set...如果外键约束指定了参照动作,主表记录做修改,删除,从表引用的列会做相应修改,或不修改,拒绝修改或设置为默认值。 引用表的列名必须是主键,且在删除引用表时必须删除引用关系或者删除当前表。

    1.9K20

    MySQL学习之路:数据的完整性-外键约束

    当向表中添加记录时,若未为字段赋值,数据库系统会自动为将字段的默认值插入。 属性名 数据类型 DEFAULT 默认值 修改购物车表cart,将购买数量的默认值设置为1。...序号 字段 数据类型 主键 外键 允许空 说明 1 cid int 是 否 类别id 2 cname varchar(30) 否 类别名称 序号 字段 数据类型 主键 外键 允许空 说明 1 gid...REFERENCES category(cid); Query OK, 0 rows affected (0.08 sec) Records: 0 Duplicates: 0 Warnings: 0 外键约束的级联更新和删除...外键约束实现了表间的引用完整性,当主表中被引用列的值发生变化时,为了保证表间数据的一致性,从表的中与该值相关的信息也应该相应更新,这就是外键约束的级联更新和删除。...SET NULL:更新和删除操作表记录时,从表中相关记录对应的值设置为NULL。 NO ACTION:不进行任何操作 RESTRICT:拒绝主表更新或修改外键的关联列。

    31520

    操作数据表

    删除主键约束 语法:ALTER TABLE tbl_name DROP PRIMARY KEY; 外键约束      外键用来在两个表的数据之间建立连接,它可以是一列或者多列。...一个表可以有一个或多个外键。外键对应的是参照完整性,一个表的外键可以为空值,若不为空值,则每一个外键值必须等于另一个表中主键的某个值。引擎必须为InnoDB。..."外键名"为定义的外键约束的名称,一个表中不能有相同名称的外键,"字段名"表示子表需要添加外键约束的字段列:"主表名"表子表外键所一来的表的名称;''主键列"表主表中定义的主键列或组合....ALTER TABLE tbl_name DROP FOREIGN KEY fk_symbol 外键约束的参照操作    1.CASCADE:从父表删除或更新且自动删除或更新子表中匹配的行(ON DELETE...            唯一约束的值可以为空值(但是只能有一个空值)               每张表可以存放多个唯一约束 2.删除唯一约束 语法:ALTER TABLE tbl_name DROP

    86460

    【数据库设计和SQL基础语法】--SQL语言概述--数据类型和约束

    主键列的值必须是唯一的,而且不允许为空。...外键约束有助于维护表之间的关系,确保在引用表中的外键列中的值存在于被引用表的主键列中。...,确保被引用的主键列与外键列的数据类型和值一致,以维护数据的完整性。...2.6 非空约束 非空约束(NOT NULL Constraint)是一种用于确保列中的数据不为空的约束。在定义表结构时,可以通过应用非空约束来防止在插入或更新记录时将空值(NULL)插入到特定列中。...这意味着在插入或更新记录时,必须为这两列提供非空的值。 如果需要在已存在的表上添加非空约束,可以使用 ALTER TABLE 语句。

    36910

    数据库基础知识:数据库中的约束和三大范式

    ; 3.默认约束 (Default Counstraint) 该数据的默认值; 4.外键约束 (Foreign Key Counstraint) 需要建立两表间的关系; 5.非空约束( Not Null...=INNODB; ②:外键与参照列的数据类型必须相同。...3、外键约束的参照操作: 当对参照表的参照字段进行删除或更新时,外键表中的外键如何应对。...参照操作可选值: RESTRICT: 拒绝对参照字段的删除或修改(默认); NO ACTION:与RESTRICT相同,但这个指令只在MySql生效; CASCADE: 删除或更新参照表的参照字段时...,外键表的记录同步删除或更新; SET NULL: 删除删除或更新参照表的参照字段时,外键表的外键设为NULL (此时外键不能设置为NOT NULL)。

    1.1K70

    【重学 MySQL】六十一、数据完整性与约束的分类

    特点:外键值必须在其所引用的主键表中存在,或者为NULL(如果允许)。外键约束有助于防止破坏表之间关系的无效数据。...即使表中的其他列允许为NULL,也可以通过非空约束保证特定列的值不为NULL。...它们作用于单个列,并限制该列的取值范围、规则和限制。常见的列级约束包括: 非空约束(NOT NULL): 定义:确保列的值不能为空。如果尝试插入或更新一个空值,则会抛出异常。...主键约束(PRIMARY KEY): 虽然在概念上主键约束通常被视为表级约束的一部分,但实际上它也可以在列级定义。主键约束确保列的值在表中是唯一的,并且不允许为空。一个表只能有一个主键。...外键约束(FOREIGN KEY): 定义:建立两个表之间的关联关系,确保关联数据的一致性。外键约束确保子表的外键列值必须在主表的参照列值范围内,或者为空(如果允许的话)。

    14010

    【重学 MySQL】六十六、外键约束的使用

    外键约束的创建条件 主表存在:主表必须已经存在于数据库中,或者是当前正在创建的表。 主键定义:必须为主表定义主键。 主键非空:主键不能包含空值,但允许在外键中出现空值。...列匹配:在主表的表名后面指定列名或列名的组合,这个列或列的组合必须是主表的主键。同时,外键中列的数目必须和主表的主键中列的数目相同。 数据类型一致:外键中列的数据类型必须和主表主键列的数据类型相同。...SET NULL: 含义:当主表中的记录被删除或更新时,子表中所有引用该记录的外键记录的外键字段会被设置为NULL。这要求子表的外键列不能为NOT NULL约束。...理论上,它意味着当主表中的记录被删除或更新时,子表中所有引用该记录的外键记录会被设置为一个默认值。 注意:由于InnoDB不支持,因此在实际应用中不会使用此约束等级。...我们希望确保每个员工都属于一个存在的部门,因此可以在employee表中为dept_id列添加外键约束,引用department表中的id列。

    12810
    领券