恶心的行标,动手擦掉它

不知道你会不会遇到这种情况,在浏览器里看人家的代码的时候,一般网页自带的代码框是有行标的,当然这是方便你查看代码,但是,当你想要把其中一段代码贴出来,放到IDE里面Run一下的时候,杯具来了,每行开头都有几个可爱的数字……

如果比较短的话,可以手动删掉,但是当你贴的是一段好几十行,甚至几百行的代码的时候,一行一行删除那几个数字,嗯,是很销魂的事情……

该程序其实就是在文件重定向的同时,去掉每行代码前面的行标,然后简单的加上了缩进(是C/C++语言风格),欢迎板砖,欢迎补充

如何使用:

将代码编译运行产生的exe文件,以及需要整理的代码(保存为 code.txt )放在同一个目录下,然后运行exe文件,生成的 code_new.txt 即为整理好的代码

 

源码:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>

char find_last(char s[]){
//找到每行有效代码的最后一个字符,也就是考虑 "//" 以及 "/**/" 的注释情况
//当然,我只考虑了每行行尾的/**/,也就是说如果代码中间嵌有的 /**/ 的情况我木有考虑,求补充
	int i,k;
	for(i=0;s[i];i++){
		if(s[i]=='/' && s[i+1]=='*' || s[i]=='/' && s[i+1]=='/')
			break;
	}

	for(k=i-1;k>=0;k--){
		if(s[k]==' ')continue;
		else return s[k];
	}
	return -1;
}

void main()
{
	char str[10000];
	int flag[100000];
	int i,j=0,space=0;
	freopen("code.txt","r",stdin);
	freopen("code_new.txt","w",stdout);
	memset(flag,0,sizeof(flag));
	while(gets(str)){
		for(i=0;str[i];i++){
			if(str[i]>='a'&&str[i]<='z' || str[i]>='A'&&str[i]<='Z' || str[i]=='#' || str[i]=='/' || str[i]=='{' || str[i]=='}')
				break;
			else str[i]=' ';
		}
		
		for(i=0;str[i];i++){
			if(str[i]==' ')continue;
			else {
				if(str[i]=='}')flag[j]=flag[j-1]-1;
				break;
			}
		}

		for(i=0;i<4*flag[j];i++)
			printf(" ");

		int fuck=0;
		for(i=0;str[i];i++){
			if(str[i]!=' ' && fuck==0)fuck=1;
			if(fuck != 0)printf("%c",str[i]);
		}
		puts("");

		char tmp=find_last(str);

		
		if(tmp=='>' || tmp==';' || tmp=='}' || tmp==')' || tmp==':' ||tmp==-1){
				flag[j+1]=flag[j];
		}
		else if(tmp=='{'){
			flag[j+1]=flag[j]+1;
		}
		j++;
	}
}


 

你可能感兴趣的:(c,浏览器,ide,exe,语言)