文件名路径有/ 导致目录不存在的问题 No such file or directory

在目录中存在/ 时,读取或写入就会报错 FileNotFoundError: [Errno 2] No such file or directory

解决办法如下:

title = "ELK CI/CD 部署实践2017-11-06 by leon.pdf"
#替换以下的 半角符号 --> 全角符号
title = title.replace('/', '/') \
    .replace('\\', '\') \
    .replace(':', ':') \
    .replace('?', '?') \
    .replace('"', '"') \
    .replace('<', "<") \
    .replace('>', ">")

拓展一下 全角半角 到底是个啥?

全角就是字母和数字等与汉字占等宽位置的字。
半角就是ASCII方式的字符,在没有汉字输入法起作用的时候输入的字母数字和字符都是半角的。

中文字符、标点符号 = 全角 = 2个字节 = 1 个字符长度
外文字母、标点符号 = 半角 = 1个字节 = 半个字符长度

:我是一个半角冒号
:我是一个全角冒号
字我是一个正常汉字

很明显 ,直观来说长度不一样,所以你可能遇到过这种坑爹的情况,replace " “,”"
去除空格发现无法去除,可能你去除的是半角,而文档中是全角 。(全半角空格的长度是不一样的)

 我是一个半角空格
 我是一个全角空格
字我是一个正常汉字
<think>好的,我现在需要帮助用户解决使用scp命令时遇到的“No such file or directory”错误。首先,我得回顾用户提供的引用内容和之前的对话,确保理解问题的上下文。用户之前遇到了Yum安装问题,现在转向了scp的问题,这可能意味着他们在尝试配置服务器间的数据传输,比如在负载均衡的节点之间同步文件。 首先,我需要分析常见的scp报错原因。根据经验,这个错误通常有几个可能的原因: 1. **本地文件存在**:用户可能输入了错误的文件路径文件名导致scp找到源文件。 2. **远程路径存在**:目标服务器上的目录路径可能存在,尤其是当用户没有使用绝对路径时。 3. **权限问题**:用户可能没有权限读取本地文件或写入远程目录。 4. **路径格式错误**:在使用scp时,路径的格式可能正确,比如遗漏了冒号或用户名。 接下来,我需要参考用户提供的引用内容。引用[1]和[2]提到了scp的基本用法和参数,引用[3]提到了传输多个文件和目录的方法,引用[4]讨论了无密码登录的问题。虽然用户当前的问题是关于认证,但引用中的信息可能对路径格式有帮助。 用户提到他们想解决“No such file or directory”的问题,并且系统是CentOS。我需要分步骤引导用户检查可能的原因。 首先,检查本地文件是否存在。用户可能在执行scp命令时路径输入错误,比如相对路径和绝对路径问题。例如,用户可能在当前目录没有正确指定文件路径,或者在复制整个目录时没有使用递归参数`-r`。引用[3]中提到了传输目录内容时使用通配符`*`,但如果目录本身存在,或者路径正确,也会导致错误。 其次,检查远程路径是否存在。如果用户指定的远程目录如`/tmp`存在,或者权限足,也会出现该错误。需要确保远程目录存在,并且用户有写入权限。引用[1]中的例子是将文件复制到`/tmp`下,但若该目录被删除或权限受限,就会失败。 然后,路径格式是否正确。scp的路径格式是`user@host:path`,如果遗漏了冒号或用户名,可能导致路径解析错误。例如,正确的格式应该是`scp /本地路径 用户@远程主机:/远程路径`,如果路径中有空格或特殊字符,可能需要使用引号包裹。 此外,权限问题也需要考虑。用户是否有权限读取本地文件和写入远程目录?本地文件的权限是否设置为可读,远程目录是否可写?特别是当使用非root用户时,可能需要sudo权限,但scp本身支持sudo,所以需要确保目标路径对用户可写。 用户可能还尝试复制目录但没有使用`-r`选项,导致scp无法递归复制,从而报错。引用[3]中提到使用`scp downloads/* user@host:uploads/`来复制目录内的所有文件,但如果是复制整个目录,需要加上`-r`参数。 另外,用户可能在远程路径中使用了相对路径,而相对路径是基于用户的家目录的。例如,如果用户指定`:/tmp`,而实际路径应该是绝对路径`/tmp`,或者用户的家目录下没有tmp目录,也会导致错误。 可能的解决方案步骤包括: 1. 检查本地文件路径是否正确,使用绝对路径。 2. 确保远程目录存在,必要时先在远程创建目录。 3. 检查路径格式是否正确,包括冒号和用户名。 4. 确认权限问题,是否有读写权限。 5. 复制目录时使用`-r`选项。 6. 使用详细模式`-v`来查看调试信息,帮助定位问题,如引用[1]提到的`scp -v`。 此外,引用[4]中提到的无密码登录可能相关,但当前错误与认证无关,所以暂时可以排除。过,如果用户配置了密钥认证但有问题,也可能导致路径解析前的连接问题,但错误信息通常同,所以可能性较低。 用户可能需要具体的命令示例,比如如何正确使用绝对路径,如何创建远程目录,如何使用`-r`参数等。同时,提醒用户在路径中包含空格或特殊字符时使用引号。 最后,验证步骤,例如执行`ls`检查文件是否存在,或者先在远程执行`mkdir -p`创建目录,再执行scp命令。 总结,我需要将这些可能的原因和解决步骤组织成清晰的解答,帮助用户逐步排查问题,并给出具体的命令示例和注意事项,确保他们能够理解并解决问题。</think>#### 解决SCP报错"No such file or directory"的完整指南 --- ### 问题原因分析 出现该错误的核心原因是**路径解析失败**,具体可能由以下情况导致: 1. **本地文件存在**:源文件路径错误或文件权限足[^1] 2. **远程路径存在**:目标服务器目录未创建或权限限制[^2] 3. **路径格式错误**:SCP语法中遗漏关键符号(如`:`或`/`) 4. **目录未递归复制**:复制文件夹时缺少`-r`参数[^3] --- ### 分步解决方案 #### 1. 验证本地文件路径 ```bash ls -l /etc/passwd # 检查源文件是否存在(示例路径) ``` - 若报错`No such file` → **修正源路径** - 权限足时使用`sudo`或调整文件权限: ```bash chmod +r /path/to/file # 添加读权限 ``` #### 2. 检查远程路径有效性 在目标服务器执行: ```bash ssh root@10.10.20.189 "ls -d /tmp" # 验证远程目录是否存在 ``` - 若目录存在则创建: ```bash ssh root@10.10.20.189 "mkdir -p /tmp" # 强制创建嵌套目录 ``` #### 3. 规范SCP路径格式 **正确格式**: ```bash scp /本地绝对路径/文件 用户名@远程IP:/远程绝对路径/ ``` **错误示例修正**: ```bash # 错误命令:遗漏冒号 scp /etc/passwd root@10.10.20.189/tmp → # 修正后: scp /etc/passwd root@10.10.20.189:/tmp ``` #### 4. 递归复制目录(关键参数) 复制文件夹必须使用`-r`参数: ```bash scp -r /本地目录/ root@10.10.20.189:/目标路径/ # 注意尾部斜杠[^3] ``` #### 5. 启用调试模式 通过`-v`参数查看详细传输过程: ```bash scp -v /etc/passwd root@10.10.20.189:/tmp/ # 显示SSH连接细节[^1] ``` --- ### 特殊场景处理 #### 场景1:复制多个文件 使用通配符时需用引号包裹路径: ```bash scp "/path/with space/*.log" root@10.10.20.189:/tmp ``` #### 场景2:使用非标准SSH端口 通过`-P`指定端口(注意大写): ```bash scp -P 2222 /data/file root@10.10.20.189:/tmp ``` #### 场景3:无密码登录配置(避免交互中断) 配置SSH密钥认证[^4]: ```bash ssh-keygen # 本地生成密钥 ssh-copy-id root@10.10.20.189 # 推送公钥到目标服务器 ``` --- ### 验证操作 ```bash # 本地验证 ls /etc/passwd | grep -q passwd && echo "源文件存在" # 远程验证 ssh root@10.10.20.189 "ls /tmp/passwd" ``` --- ### 流程图辅助诊断 ```mermaid graph TD A[SCP报错] --> B{本地文件存在?} B -->|否| C[修正源路径] B -->|是| D{远程目录存在?} D -->|否| E[ssh创建远程目录] D -->|是| F{路径含特殊字符?} F -->|是| G[添加引号] F -->|否| H[检查权限配置] ``` --- #### 相关问题 1. 如何通过SCP保留文件属性(如修改时间)? 2. SCP传输速度慢有哪些优化方法? 3. 如何限制SCP传输带宽?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值