utf-8 和 unicode之间关系

ascii、latin、gbk、Big5、unicode都是字符集,用字节来表示字符,除了ascii是1个字节表示字符外,
其它都是使用2个字节表示字符。

为了统一,国际标准化组织 ISO,制定unicode用2个字节来统一全世界所有字符。


美国人不同意,因为unicode是2个字节,相比他之前的ascii的1个字节,增加了1倍的储存空间。于是国际标准化组织提出了一种方案,用UTF-8对unicode进行压缩,由2个字节压缩为1个字节。中文转换以后 3 个字节(中文比较特殊,压缩后反而占内存变3个字节,占空间增大),UTF-8 转换过程中会最终生成的是  1-6 个字节不等的数据


所以说UTF-8是Unicode的压缩,也就是编码。

unicode码是字符串类型,只存在内存中,传输(网络)或者存储(硬盘)必须进行编码,如UTF-8 / UTF-16 / UTF-32 / GBK / GB2312(字节,是二进制数据)

 

# 1. 导入模块

import urllib.request
import urllib.parse
wd = input("请输入查询内容:")

# 2. 发送请求 获取响应

url = "https://www.baidu.com/s?wd="
# 创建请求对象
request = urllib.request.Request(
    url=url + urllib.parse.quote(wd),# urllib.parse.quote 把 url 进行转义
    headers={
        "User-Agent":"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 Safari/537.36"
    }
)
# 获取响应
response = urllib.request.urlopen(request)

# 3. 处理数据

data = response.read()
# 把二进制 通过 UTF-8 解码成 unicode
string = data.decode('utf-8')

# 如果写入是一个 w 其实内部需要操作 字符串 转 二进制 写入硬盘
# unicode 数据 编码成 UTF-8
with open('01-baidu.html','w',encoding='utf-8') as f:
    f.write(string)

 

unicode码是字符串类型,只存在内存中,传输(网络)或者存储(硬盘)必须进行编码,如UTF-8 / UTF-16 / UTF-32 / GBK / GB2312(字节,是二进制数据)。

data = response.read()是从网络上传输的数据,是二进制数据;因为以w模式写入,得是字符串,所以要用utf-8解码;而写入硬盘,在硬盘中数据形式得是二进制,所以要encoding='utf-8'进行编码,转成二进制。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在C语言中,将Unicode编码转换为UTF-8可以通过一定的算法和编码规则实现。UTF-8是一种变长的字符编码方式,它可以表示Unicode字符集中的所有字符。 首先需要明确Unicode编码和UTF-8编码之间的映射关系Unicode是一个字符集,为每个字符分配了一个唯一的编码点,它是一种固定宽度编码。而UTF-8Unicode字符集中的字符用变长字节序列进行编码的一种方式。 具体操作上,我们可以借助C语言提供的字符串处理函数和位运算来实现UnicodeUTF-8的转换。以下是一个简单的示例代码: ``` #include <stdio.h> void unicodeToUtf8(int unicode) { if (unicode < 0x80) { // 单字节编码 printf("%c", (char)unicode); } else if (unicode < 0x800) { // 双字节编码 printf("%c", (char)((unicode >> 6) | 0xC0)); printf("%c", (char)((unicode & 0x3F) | 0x80)); } else if (unicode < 0x10000) { // 三字节编码 printf("%c", (char)((unicode >> 12) | 0xE0)); printf("%c", (char)(((unicode >> 6) & 0x3F) | 0x80)); printf("%c", (char)((unicode & 0x3F) | 0x80)); } else if (unicode < 0x110000) { // 四字节编码 printf("%c", (char)((unicode >> 18) | 0xF0)); printf("%c", (char)(((unicode >> 12) & 0x3F) | 0x80)); printf("%c", (char)(((unicode >> 6) & 0x3F) | 0x80)); printf("%c", (char)((unicode & 0x3F) | 0x80)); } } int main() { int unicode = 0x4E2D; // Unicode 编码点,例如中文字符 "中" unicodeToUtf8(unicode); return 0; } ``` 上述代码实现了一个简单的函数`unicodeToUtf8`,它接受一个Unicode编码点作为参数,并将其转换为对应的UTF-8编码存储。在`main`函数中,我们将Unicode编码点设置为0x4E2D,即中文字符"中"的Unicode编码,并调用`unicodeToUtf8`进行转换和输出。 需要注意的是,该示例代码只是一个简单的示例,实际应用中需要更完善的处理逻辑,并且UTF-8编码还需要考虑一些特殊情况和规则,例如字节数限制、BOM头等。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值