字符集转化/curses

简介: <div style="font-family:'Microsoft YaHei UI','Microsoft YaHei',SimSun,'Segoe UI',Tahoma,Helvetica,sans-serif,'Microsoft YaHei',Georgia,Helvetica,Arial,sans-serif,宋体,PMingLiU,serif; font-size:14.07
linux字符串转化使用方法
第一步: iconv_open(目标字符集,源字符集)
第二步: iconv()实现字符集转化
第三步: iconv_close()关闭iconv

命令:iconv --list
显示系统中支持的字符集

//makefile
.SUFFIXES: .c .o
CC=gcc
SRCS=mydaemon.c
OBJS=$(SRCS:.c=.o)
EXEC=mydaemon
all: $(OBJS)
    $(CC)  -o $(EXEC) $(OBJS) 
    @echo '-------------ok--------------'
.c.o:
    $(CC) -g  -o $@ -c $< 
clean:
    rm -f $(OBJS) 
    rm -f core*
//iconv.c
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <errno.h>
#include <iconv.h>
int gbk2utf8(char *src, size_t *srclen, char *dest, size_t *destlen)
{
    iconv_t cd = iconv_open("UTF8", "GBK");//源字符串为gbk,目标为utf8
    if (cd ==(iconv_t)-1)
    {
        printf("open iconv error %s\n", strerror(errno));
        return -1;
    }
    size_t rc = iconv(cd, &src, srclen, &dest, destlen);//将src字符串转化为目标dest
    if (rc == (size_t)-1)
    {
        printf("iconv error %s\n", strerror(errno));
        return -1;
    }
    iconv_close(cd);
    return 0;
}
int main(int arg, char *args[])
{
    if (arg < 2)
    {
        printf("Usage: xxx yyy");
        return -1;
    }
    FILE *p = fopen(args[1], "r");
    if (p == NULL)
    {
        printf("open %s error, %s\n", args[1], strerror(errno));
        return -1;
    }
    char buf[1024];//定义一个buffer,存放读取到的文件内容
    char destbuf[1024];//定义一个buffer,存放转化完字符串后的内容
    while(1)
    {
        memset(buf, 0, sizeof(buf));
        memset(destbuf, 0, sizeof(destbuf));
        if (fgets(buf, sizeof(buf), p) == NULL)//读出一行,如果是文件最后一行,循环退出
        {
            break;
        }
        size_t srclen = strlen(buf);
        size_t destlen = sizeof(destbuf);
        gbk2utf8(buf, &srclen, destbuf, &destlen);
        printf("%s\n", destbuf);
    }
    fclose(p);
    return 0;
}

运行:
在windows下面编辑一个文件,将文件传到linux上面之后,cat 文件内容为乱码。



curses是一个在Linux/Unix下广泛应用的图形函数库.
linux下面安装软件的时候,会在屏幕的任意位置输出字符,进行进度的显示。
//makefile
.SUFFIXES: .c .o
CC=gcc
SRCS=curses.c
OBJS=$(SRCS:.c=.o)
EXEC=mydaemon
all: $(OBJS)
    $(CC)  -o $(EXEC) $(OBJS) -lcurses
    @echo '-------------ok--------------'
.c.o:
    $(CC) -g  -o $@ -c $< 
clean:
    rm -f $(OBJS) 
    rm -f core*

//curses.c
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <errno.h>
#include <curses.h>
int main()
{
    initscr();//开始图形模式
    noecho();//不回显
    char temp[128];
    char s[128];
    int seq = 0;
    while (scanf("%s", s))
    {
        if (strcmp(s, "exit") == 0)
        {
            break;
        }
        clear();//清除屏幕
        sprintf(temp, "please input:");
        mvaddstr(0, 0, temp);//在指定的坐标打印
        int i;
        for (i=0; i<10; i++)
        {
            sprintf(temp, "%s %d %s", s, seq++, s);
            mvaddstr(i+1, 0, temp);
        }
        move(0, 13);//移动光标到指定坐标
        refresh();//刷新屏幕,如果不刷新屏幕,那么mvaddstr和move将不生效
    }
    endwin();//结束图形模式
    return 0;
}

运行:

目录
相关文章
|
4月前
|
编解码 Python Windows
Python写入文件报错‘gbk’ codec can’t encode character的解决办法
Python写入文件报错‘gbk’ codec can’t encode character的解决办法
74 2
|
10月前
|
存储 Windows
“浅入深处“编码历史,字符串编码(ASCII, GBK, ANSI, Unicode, UTF-8编码),为什么记事本默认ANSI编码,Unicode和UTF8有什么区别
“浅入深处“编码历史,字符串编码(ASCII, GBK, ANSI, Unicode, UTF-8编码),为什么记事本默认ANSI编码,Unicode和UTF8有什么区别
|
12月前
|
JSON PHP 数据格式
【python】or【php】网页中字符编码转换,将反斜杠u \u字符串转为unicode/utf8
【python】or【php】网页中字符编码转换,将反斜杠u \u字符串转为unicode/utf8
109 0
|
编解码 测试技术 Python
Python UnicodeEncodeError 'ascii' codec can't encode character 错误解决方法
Python UnicodeEncodeError 'ascii' codec can't encode character 错误解决方法
74 0
|
编解码 芯片
[oeasy]python0112_扩展ascii_Extended_ascii_法文字符
[oeasy]python0112_扩展ascii_Extended_ascii_法文字符
91 0
|
安全
[oeasy]python0 113_字符编码_VT100控制码_iso_8859_1_拉丁字符_latin
[oeasy]python0 113_字符编码_VT100控制码_iso_8859_1_拉丁字符_latin
114 0
[oeasy]python0 113_字符编码_VT100控制码_iso_8859_1_拉丁字符_latin
Python__24--格式化字符串与字符串的编码、解码转换
驻留机制、格式化字符串与字符串的编码、解码转换
|
Python
ASCII编码(Python扩展)
了解ASCII.和他的作用。
153 0
ASCII编码(Python扩展)
|
JSON 数据格式 Python
Python如何将unicode转换为中文
今天碰到一个很有意思的问题,需要将普通的 Unicode字符串转换为 Unicode编码的字符串
677 0
Python如何将unicode转换为中文