删除每个输入行末尾的空格,制表符,并删除全空格行

本文介绍了一种使用C语言编写的程序,该程序能够删除文本输入中的空白行并在每行末尾去除多余的空格和制表符。通过两个不同的实现方式展示了如何有效地处理这些常见文本格式问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

     源自《The C Programming Language》P22 pr1-18:

 

     编写一个程序,删除每个输入行末尾的空格,制表符,并删除完全是空格的行

 

     代码:

 

    

 

 

     分析:

 

     1,   针对输入的字符串(line)的倒数第二个字符是否为'/n',分情况进行消除字符串末尾的空格及制表符处理。

 

     2,   针对处理后的字符串(post_line[n])的倒数第二个字符是否为'/n',在打印的时候分情况进行处理。

 

     3,   getLine函数:读入一行字符后,将输入缓冲区清空,这样当超过字符数组line的界限的字符会被清除掉,

                                如果不清空,则在下次调用getLine函数时,上次超出的字符部分会被getchar函数直接

                                读到这次的line字符数组中,造成混乱。

 

     参考代码:

 

    

 

 

     分析:

 

     1,  对比于自己实现的代码,发现这段代码简洁多了,思路也很清晰和易懂。

 

     2,  有点缺憾之处:(a),每次输入一行字符,处理结果会紧接着下一行输出,不太容易观看,

                               而上面那段代码就不存在这个问题。

                               (b),参考代码没有考虑一行字符串没有'/n'的情况,这和它将MAXLINE设成1000有关,

                                      极端的情况是一个字符串就是1000个字符,并且倒数第二字符不是'/n',如果MAXLINE

                                      的值比较小的话,这个问题就凸现出来了,相比于此,上段代码考虑了这种情况。

                                      修改remove函数:

                                      while(s[i] != '/n' && i < MAXLINE - 2)

                                                ++i;

                                      if(i != MAXLINE - 2)

                                                 --i;

                                      while(i >= 0 && (s[i] == ' ' || s[i] == '/t'))

                                                 --i;

                                       if( i >= 0 && i < MAXLINE - 2)

                                       {

                                                 ++i;

                                                 s[i] = '/n';

                                                 ++i;

                                                 s[i] = '/0'; 

                                       }   

 

 

 

 

 

<think>好的,用户的问题是关于在SQL中使用正则表达式匹配换符、制表符空格等特殊字符。首先,我需要回忆不同数据库系统对正则表达式的支持情况,因为不同的数据库可能有不同的语法。 用户提到的引用[3]中有提到使用regexp_like和regexp_replace,这可能涉及到Oracle或者PostgreSQL。比如在Oracle中,正则表达式的语法可能需要使用特定的转义字符,而像换符、制表符这些特殊字符可能需要用\n或者\t来表示。不过,不同数据库的处理方式可能不同,比如MySQL中使用的是POSIX正则表达式,而PostgreSQL使用PCRE。 接下来,我需要确认如何表示这些特殊字符。通常,正则表达式中换符是\n,制表符是\t,空格可以直接用空格或者\s(匹配任何空白字符,包括空格制表符、换页符等)。但需要注意数据库是否支持这些转义序列,或者是否需要使用额外的转义。例如,在某些情况下可能需要使用双反斜杠,或者在SQL字符串中使用转义。 另外,引用[3]中的例子用了正则表达式'^[mx|zb]',这可能存在错误,因为方括号内的|会被当作普通字符,正确的应该是'^(mx|zb)'。不过这可能只是示例中的笔误。但这也提醒我要注意用户可能对正则表达式语法不够熟悉,需要详细解释。 然后,用户的需求是匹配这些特殊字符,可能需要给出具体的正则表达式模式。例如,匹配换符用\n,制表符用\t,空格空格或者\s。但需要确认数据库是否支持这些转义。例如,在Oracle中,可能需要使用chr(9)表示制表符,chr(10)表示换符,但正则表达式中是否可以直接用\t和\n呢? 另外,引用[1]中提到正则表达式的修饰符,比如'm'用于多匹配,这可能会影响^和$的为,但用户的问题是关于特殊字符的匹配,可能需要不同的修饰符,比如是否启用点号匹配换符('n'修饰符),不过用户的问题主要不是关于点号,而是如何正确匹配这些特殊字符本身。 还需要考虑不同数据库的差异,比如MySQL的REGEXP默认不支持\s,可能需要使用[ \t\n\r]这样的字符类。而PostgreSQL的REGEXP支持PCRE,所以可以使用\s来匹配任何空白字符,包括空格制表符、换等。 总结一下,回答应该包括以下几点: 1. 不同数据库系统的正则表达式支持情况,比如Oracle、PostgreSQL、MySQL。 2. 如何在这些数据库中表示换符、制表符空格,是否需要转义或使用特定语法。 3. 示例SQL语句,展示如何匹配这些字符。 4. 注意事项,如转义字符的使用、修饰符的影响等。 同时,用户提供的引用[3]中的例子可能有误,需要指出正确的写法,比如在Oracle中使用regexp_like时,如何正确使用转义字符。例如,匹配换符可能需要使用\n,但需要确保数据库正确解析该转义,可能需要使用ESCAPE子句或者设置匹配模式。 最后,需要确保回答符合用户的要求,使用中文,结构清晰,正确使用LaTeX格式,末尾生成相关问题。</think>在 SQL 中通过正则表达式匹配特殊字符时,需要根据不同数据库系统的正则表达式实现语法进操作。以下是针对换符、制表符空格等特殊字符的匹配方法: --- ### 1. **通用正则表达式符号** 正则表达式中特殊字符的表示方式: - **换符**:`\n`(Unix 系统)或 `\r\n`(Windows 系统) - **制表符**:`\t` - **空格**:直接使用空格字符或 `\s`(匹配所有空白字符,包括空格制表符、换符等) --- ### 2. **不同数据库的具体实现** #### **Oracle** - 使用 `REGEXP_LIKE` 函数,通过 `chr()` 函数或转义字符表示特殊符号: ```sql -- 匹配包含换符的字段 SELECT * FROM table WHERE REGEXP_LIKE(column, '\n'); -- 匹配包含制表符的字段 SELECT * FROM table WHERE REGEXP_LIKE(column, '\t'); -- 匹配包含空格制表符的字段 SELECT * FROM table WHERE REGEXP_LIKE(column, '[ \t]'); ``` 注意:Oracle 需启用多模式时,可添加 `'m'` 修饰符[^1]。 #### **PostgreSQL** - 使用 `~` 操作符和 PCRE 语法: ```sql -- 匹配包含换符的字段 SELECT * FROM table WHERE column ~ '\n'; -- 匹配任意空白字符(包括空格制表符、换符) SELECT * FROM table WHERE column ~ '\s'; ``` #### **MySQL** - 使用 `REGEXP` 操作符,但需注意 MySQL 默认不支持 `\s`: ```sql -- 匹配换符或制表符 SELECT * FROM table WHERE column REGEXP '[\n\t]'; -- 匹配空格字符 SELECT * FROM table WHERE column REGEXP '[ ]'; ``` --- ### 3. **匹配特殊字符的通用技巧** - **转义字符处理**:某些数据库需对反斜杠 `\` 进转义(如 MySQL 需写成 `\\n`)。 - **字符类简化**:使用 `\s` 匹配所有空白字符(需数据库支持 PCRE 语法)。 - **ASCII 码表示**:部分数据库支持通过 ASCII 码匹配,如 Oracle 的 `chr(9)` 表示制表符[^3]。 --- ### 4. **示例:替换特殊字符** 在 SQL 中使用 `REGEXP_REPLACE` 清理特殊字符(以 Oracle 为例): ```sql -- 替换换符、制表符空格为单个空格 SELECT REGEXP_REPLACE(column, '[\n\t ]+', ' ') FROM table; ``` --- ### 注意事项 1. **数据库兼容性**:不同数据库的正则表达式实现差异较大,需参考具体文档[^4]。 2. **性能影响**:正则表达式操作可能降低查询效率,建议对大数据量字段添加索引或预处理[^3]。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值