纯血鸿蒙APP实战开发——GBK文本格式解码

144 篇文章 3 订阅
31 篇文章 0 订阅

介绍

本示例介绍使用第三方库的Axios获取GBK格式的网络数据时,通过util实现GBK转换UTF-8格式。该场景多用于需要转换编码格式的应用。

效果图预览

使用说明

直接进入页面就可获取GBK格式的用户名信息并进行解码操作。

实现思路

  1. 使用第三方库Axios获取网络数据,并将获取数据类型设置为ARRAY_BUFFER。
    axios<string, AxiosResponse<string>, null>({
      method: "get",
      url: URL,
      responseType: 'ARRAY_BUFFER'
    })
  1. 使用util.TextDecoder方法进行解码操作。
    let textDecoder = util.TextDecoder.create('gbk', { ignoreBOM: true });
    let result = new Uint8Array(res.data);
    let resultString = textDecoder.decodeWithStream(result, { stream: false });
  1. 将解码后的数据通过LazyForEach循环显示在列表中。
    LazyForEach(this.friendsListData, (msg: FriendData) => {
      ListItem() {
        ...
      }
    })

工程结构&模块类型

   gbktranscoding                                  // har类型
   |---pages
   |---|---FriendsBook.ets                         // 视图层-场景列表页面

模块依赖

@ohos/axios

参考资料

Axios网络请求库

也为了积极培养鸿蒙生态人才,让大家都能学习到鸿蒙开发最新的技术,针对一些在职人员、0基础小白、应届生/计算机专业、鸿蒙爱好者等人群,整理了一套纯血版鸿蒙(HarmonyOS Next)全栈开发技术的学习路线【包含了大厂APP实战项目开发】

本路线共分为四个阶段:

第一阶段:鸿蒙初中级开发必备技能

在这里插入图片描述

第二阶段:鸿蒙南北双向高工技能基础:gitee.com/MNxiaona/733GH

第三阶段:应用开发中高级就业技术

第四阶段:全网首发-工业级南向设备开发就业技术:gitee.com/MNxiaona/733GH

《鸿蒙 (Harmony OS)开发学习手册》(共计892页)

如何快速入门?

1.基本概念
2.构建第一个ArkTS应用
3.……

开发基础知识:gitee.com/MNxiaona/733GH

1.应用基础知识
2.配置文件
3.应用数据管理
4.应用安全管理
5.应用隐私保护
6.三方应用调用管控机制
7.资源分类与访问
8.学习ArkTS语言
9.……

基于ArkTS 开发

1.Ability开发
2.UI开发
3.公共事件与通知
4.窗口管理
5.媒体
6.安全
7.网络与链接
8.电话服务
9.数据管理
10.后台任务(Background Task)管理
11.设备管理
12.设备使用信息统计
13.DFX
14.国际化开发
15.折叠屏系列
16.……

鸿蒙开发面试真题(含参考答案):gitee.com/MNxiaona/733GH

鸿蒙入门教学视频:

美团APP实战开发教学:gitee.com/MNxiaona/733GH

写在最后

  • 如果你觉得这篇内容对你还蛮有帮助,我想邀请你帮我三个小忙:
  • 点赞,转发,有你们的 『点赞和评论』,才是我创造的动力。
  • 关注小编,同时可以期待后续文章ing🚀,不定期分享原创知识。
  • 想要获取更多完整鸿蒙最新学习资源,请移步前往小编:gitee.com/MNxiaona/733GH

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在使用 Python 的 requests 库进行请求时,如果返回的响应内容编码方式为 GBK,可以使用以下方法进行解码: ```python import requests resp = requests.get(url) resp.encoding = 'gbk' content = resp.text.encode('iso-8859-1').decode('gbk') ``` 其中,`resp.encoding = 'gbk'` 指定了响应内容的编码方式为 GBK。但是,由于 requests 库默认使用的是 UTF-8 编码方式,因此需要将响应内容先转换成 ISO-8859-1 编码再进行解码。 另外,如果你经常需要处理 GBK 编码的内容,也可以考虑使用 chardet 库来自动识别编码方式,例如: ```python import requests import chardet resp = requests.get(url) encoding = chardet.detect(resp.content)['encoding'] content = resp.content.decode(encoding) ``` 这里使用了 chardet.detect 方法来自动识别响应内容的编码方式,然后再进行解码。 ### 回答2: Python中的requests库是一个常用的HTTP客户端库,可以用于发送HTTP请求和获取HTTP响应。在处理HTTP响应时,requests库通常会根据响应中的Content-Type自动进行解码。 对于Content-Type为text/html的响应,requests库会根据响应头中的charset字段指定的编码格式进行解码。而对于某些网页,特别是中文网页,它们的编码格式可能是gbk。如果不进行正确的解码,可能会导致显示乱码。 为了解决这个问题,我们可以通过设置requests库的encoding属性为'gbk',来指定解码编码。 例如: ``` import requests response = requests.get('http://example.com') # 发送GET请求 response.encoding = 'gbk' # 设置解码编码为gbk print(response.text) # 打印响应内容 ``` 上述代码会发送一个GET请求到'http://example.com',并将响应内容的解码编码设置为'gbk',最后打印响应内容。 这样做可以确保响应内容以gbk编码进行解码,从而正确显示中文内容,避免出现乱码情况。 总结来说,Python的requests库中使用response.encoding = 'gbk'来对gbk编码进行解码,从而正确显示中文内容。 ### 回答3: Python的requests库默认使用UTF-8编码,但当我们访问某些中文网站时,可能会遇到GBK编码的页面。在使用requests库访问这样的网站时,我们可以通过指定响应的编码方式来进行GBK解码。 假设我们使用requests库发送一个GET请求并获取到响应,可以通过以下步骤进行GBK解码: 1. 首先,导入requests库:`import requests` 2. 然后,发送GET请求并获取响应:`response = requests.get(url)` 3. 接下来,设置响应的编码方式为GBK:`response.encoding = 'GBK'` 4. 最后,我们可以通过`response.text`来获取解码后的文本内容,即可处理中文字符了。 下面是一个示例: ```python import requests url = 'http://example.com' response = requests.get(url) response.encoding = 'GBK' text = response.text print(text) ``` 以上代码会向'http://example.com'发送一个GET请求,并将响应的编码方式设置为GBK。然后,我们可以通过`response.text`获取解码后的文本内容,可以在输出结果中看到正确显示的中文字符。 通过以上步骤,我们就可以在使用requests库时正确解码中文。当然,在实际应用中,我们还可以根据需要进行异常处理,以确保程序的稳定性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值