xcode 10以后的方法,一般使用

#ifdef DEBUG
#define NSLog(FORMAT, ...) fprintf(stderr,"\n %s:%d %s\n",[[[NSString stringWithUTF8String:__FILE__] lastPathComponent] UTF8String],__LINE__, [[[NSString alloc] initWithData:[[NSString stringWithFormat:FORMAT, ##__VA_ARGS__] dataUsingEncoding:NSUTF8StringEncoding] encoding:NSNonLossyASCIIStringEncoding] UTF8String]);
#else
#define NSLog(...)
#endif xcode 10以前的是方法一般重写NSArray的descriptionWithLocale  方法

//

//  NSDictionary+CBLog.m

//  CaiBao

//

//  Created by cb_2018 on 2019/2/21.

//  Copyright © 2019 91cb. All rights reserved.

//

#import "NSDictionary+CBLog.h"

#import <objc/runtime.h>

@implementation NSDictionary (CBLog)

#ifdef DEBUG

+ (void)load

{

static dispatch_once_t onceToken;

dispatch_once(&onceToken, ^{

zx_swizzleSelector([self class], @selector(descriptionWithLocale:indent:), @selector(zx_descriptionWithLocale:indent:));

});

}

- (NSString *)zx_descriptionWithLocale:(id)locale indent:(NSUInteger)level

{

return [self stringByReplaceUnicode:[self zx_descriptionWithLocale:locale indent:level]];

}

- (NSString *)stringByReplaceUnicode:(NSString *)unicodeString

{

NSMutableString *convertedString = [unicodeString mutableCopy];

[convertedString replaceOccurrencesOfString:@"\\U" withString:@"\\u" options:0 range:NSMakeRange(0, convertedString.length)];

CFStringRef transform = CFSTR("Any-Hex/Java");

CFStringTransform((__bridge CFMutableStringRef)convertedString, NULL, transform, YES);

return convertedString;

}

static inline void zx_swizzleSelector(Class theClass, SEL originalSelector, SEL swizzledSelector)

{

Method originalMethod = class_getInstanceMethod(theClass, originalSelector);

Method swizzledMethod = class_getInstanceMethod(theClass, swizzledSelector);

BOOL didAddMethod =

class_addMethod(theClass,

originalSelector,

method_getImplementation(swizzledMethod),

method_getTypeEncoding(swizzledMethod));

if (didAddMethod) {

class_replaceMethod(theClass,

swizzledSelector,

method_getImplementation(originalMethod),

method_getTypeEncoding(originalMethod));

} else {

method_exchangeImplementations(originalMethod, swizzledMethod);

}

}

#endif

@end

 

//

//  NSArray+CBLog.m

//  CaiBao

//

//  Created by cb_2018 on 2019/2/21.

//  Copyright © 2019 91cb. All rights reserved.

//

#import "NSArray+CBLog.h"

@implementation NSArray (CBLog)

#ifdef DEBUG

- (NSString *)description {

return [self jl_descriptionWithLevel:1];

}

-(NSString *)descriptionWithLocale:(id)locale

{

return [self jl_descriptionWithLevel:1];

}

- (NSString *)descriptionWithLocale:(nullable id)locale indent:(NSUInteger)level {

return [self jl_descriptionWithLevel:(int)level];

}

/**

将数组转化成字符串,文字格式UTF8,并且格式化

@param level 当前数组的层级,最少为 1,代表最外层

@return 格式化的字符串

*/

- (NSString *)jl_descriptionWithLevel:(int)level {

NSString *subSpace = [self jl_getSpaceWithLevel:level];

NSString *space = [self jl_getSpaceWithLevel:level - 1];

NSMutableString *retString = [[NSMutableString alloc] init];

// 1、添加 [

[retString appendString:[NSString stringWithFormat:@"["]];

// 2、添加 value

[self enumerateObjectsUsingBlock:^(id  _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {

if ([obj isKindOfClass:[NSString class]]) {

NSString *value = (NSString *)obj;

value = [value stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding];

NSString *subString = [NSString stringWithFormat:@"\n%@\"%@\",", subSpace, value];

[retString appendString:subString];

} else if ([obj isKindOfClass:[NSArray class]]) {

NSArray *arr = (NSArray *)obj;

NSString *str = [arr jl_descriptionWithLevel:level + 1];

str = [NSString stringWithFormat:@"\n%@%@,", subSpace, str];

[retString appendString:str];

} else if ([obj isKindOfClass:[NSDictionary class]]) {

NSDictionary *dic = (NSDictionary *)obj;

NSString *str = [dic descriptionWithLocale:nil indent:level + 1];

str = [NSString stringWithFormat:@"\n%@%@,", subSpace, str];

[retString appendString:str];

} else {

NSString *subString = [NSString stringWithFormat:@"\n%@%@,", subSpace, obj];

[retString appendString:subString];

}

}];

if ([retString hasSuffix:@","]) {

[retString deleteCharactersInRange:NSMakeRange(retString.length-1, 1)];

}

// 3、添加 ]

[retString appendString:[NSString stringWithFormat:@"\n%@]", space]];

return retString;

}

/**

根据层级,返回前面的空格占位符

@param level 层级

@return 占位空格

*/

- (NSString *)jl_getSpaceWithLevel:(int)level {

NSMutableString *mustr = [[NSMutableString alloc] init];

for (int i=0; i<level; i++) {

[mustr appendString:@"\t"];

}

return mustr;

}

#endif

@end

 、、、、、、、、、、、、、、、、、

另外只重写的方法

@implementation NSDictionary (Log)

- (NSString *)descriptionWithLocale:(id)locale

{

NSMutableString *str = [NSMutableString string];

[str appendString:@"{\n"];

// 遍历字典的所有键值对

[self enumerateKeysAndObjectsUsingBlock:^(id key, id obj, BOOL *stop) {

[str appendFormat:@"\t%@ = %@,\n", key, obj];

}];

[str appendString:@"}"];

// 查出最后一个,的范围

NSRange range = [str rangeOfString:@"," options:NSBackwardsSearch];

if (range.length != 0) {

// 删掉最后一个,

[str deleteCharactersInRange:range];

}

return str;

}

@end

@implementation NSArray (Log)

- (NSString *)descriptionWithLocale:(id)locale

{

NSMutableString *str = [NSMutableString string];

[str appendString:@"[\n"];

// 遍历数组的所有元素

[self enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {

[str appendFormat:@"%@,\n", obj];

}];

[str appendString:@"]"];

// 查出最后一个,的范围

NSRange range = [str rangeOfString:@"," options:NSBackwardsSearch];

if (range.length != 0) {

// 删掉最后一个,

[str deleteCharactersInRange:range];

}

return str;

}

@end

、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、

iOS Xcode打印汉字, 而不是UTF8编码

2017年06月21日 15:15:41 小朱泽龙 阅读数:237

http://blog.csdn.net/Cloud_Pro/article/details/53391656

为NSArray添加分类

#import "NSArray+decription.h"

@implementation NSArray (decription)

- (NSString *)descriptionWithLocale:(id)locale

{

NSMutableString *str = [NSMutableString stringWithFormat:@"%lu (\n", (unsigned long)self.count];

for (id obj in self) {

[str appendFormat:@"\t%@, \n", obj];

}

[str appendString:@")"];

return str;

}

@end

为NSDictionary添加分类

#import "NSDictionary+decription.h"

@implementation NSDictionary (decription)

- (NSString *)descriptionWithLocale:(id)locale

{

NSArray *allKeys = [self allKeys];

NSMutableString *str = [[NSMutableString alloc] initWithFormat:@"{\t\n "];

for (NSString *key in allKeys) {

id value= self[key];

[str appendFormat:@"\t \"%@\" = %@,\n",key, value];

}

[str appendString:@"}"];

return str;

}

@end

、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、

iOS网络请求返回的汉字在日志里会显示成\U63d0\U4ea4\U6210\U529f,用下面的脚本就可以把Unicode显示成汉字

#!/bin/sh

cmd="/usr/bin/env python -c 'print(\"\"\"$1\"\"\".lower().decode(\"unicode-escape\").encode(\"utf-8\"))'"

echo $cmd | sh

比如:把这个脚本命名为co,并使用chmod +x co添加可执行属性

使用co '\U63d0\U4ea4\U6210\U529f'就可以显示汉字了。

链接:https://www.jianshu.com/p/

Xcode中控制台中打印中文处理的更多相关文章

  1. xcode中自定义log打印

    打印内容包括 在哪个文件中 ? 在哪个方法中? 将要执行什么操作?   // 此打印实现前提: // 1.在.pch文件中实现自定义log打印方法,log名换为LCLog // 2.定义一个宏obje ...

  2. spring boot 在IDEA控制台中打印彩色日志

    只需要在application.properties中加入 spring.output.ansi.enabled=ALWAYS 即可

  3. Java控制台中输入中文输出乱码的解决办法

    Run---Run Configurations---Common---Encoding---Other---GBK Run Configurations里的Common中将编码方式改成GBK就正常了

  4. 关于 JavaScript 中一个小细节问题 (在控制台中直接 {Name:'王尼玛',Age:20} 对象报错问题)

    在 Chrome 浏览器,大家可能遇到这样一个小问题. 随便输入一个 Object 对象  ,比如 {Name:'王尼玛',Age:20} ,将会报错.之前,也从来没去考虑过到底是为啥原因. 今天,刚 ...

  5. python中打印中文

    python中打印中文 在python 2.x版本中,默认是ASCII编码方式,在有业务需要输入中文时,就会出现乱码的情况.解决这种问题的一个方式就是设置py文件的编码方式.实现方式如下: 在py文件 ...

  6. Xcode中利用git源代码版本号控制

    git是一个版本号控制系统,能够通过命令行来调用,也有专门的桌面软件.这里主要介绍在Xcode中怎样利用git来进行版本号的控制. 一.创建git源 从Xcode5開始引入了使用git的一些新特性.将 ...

  7. python在windows系统中打印中文乱码

    转自:http://www.111cn.net/phper/python/58920.htm 中文乱码对于程序开发人员来讲不是什么怪事情了,今天我在使用python打印中文时就出现乱码了,下面我们一起 ...

  8. php部分:网页中报表的打印,并用CSS样式控制打印的部分;

    网页中报表的打印,是通过调用window对象中的print()方法实现打印功能的: 调用浏览器本身的打印功能实现打印 <a href="#" onclick="wi ...

  9. 发现日志文件和打印在eclipse控制台中的编码不一致

    发现日志文件和打印在eclipse控制台中的编码不一致,正好相反. 日志文件是用notepad打开的,notepad有自己的编码方式,查询编码为utf-8,日志文件汉字等等显示正常. 但是在eclip ...

随机推荐

  1. Java的基础知识二

    一.方法函数 函数也称为方法,就是定义在类中的具有特定功能的一段独立代码.用于定义功能,提高代码的复用性. 函数的特点1> 定义函数可以将功能代码进行封装,便于对该功能进行复用:2> 函数 ...

  2. 基于centOS7:新手篇→tomcat安装配置

    1.新环境,还没有安装lrzsz和unzip,先安装 yum -y install lrzsz yum -y install unzip 2.进入tomcat官网下载安装包,使用rz上传到服务器opt ...

  3. 7个小技巧,解决eclipse卡顿问题

    eclipse作为开发工具,每天都要使用,你肯定遇到过eclipse卡到想哭的时刻,严重影响开发效率啊!如果内存条不要钱,那就加内存吧!一个不够加两个!当然这都是玩笑话,如果不花钱也能解决问题,希望下 ...

  4. nuxt拦截IE浏览器

    需求场景 判断浏览器类型,让譬如IE的低版本浏览器跳转到指定提示浏览器升级页面. 难点分析 使用过的都知道,nuxt没有暴露主入口页面也就是index.html啊,我们以前常用的IE条件判断没地方写. ...

  5. Linux之权限详解

    如何知道你有什么权限 我能干什么?这是我最关心的问题! 切换到普通用户 [root@luffy-01 ~]# su - pizza [pizza@luffy-01 ~]$ ls /root ls: c ...

  6. HTTP协议中GET和POST的区别(详细描述)

    HTTP协议在现代网络通信中被广泛应用,在HTTP 1.0版本中有7种请求方式,在HTTP 1.1版本中有8种请求方式,而这些请求方式中最常用的就是GET和POST,网上关于GET与POST请求方式的 ...

  7. 转://因触发器限制导致oracle用户登录失败

    使用PL/SQL DEV登录数据库时,出现如下错误 手工创建了test用户,通过dev工具登录没问题.怀疑数据库中有些用户限制了登录的.再看错误编号:ORA-20001,oracle保留的异常错误号范 ...

  8. 用户对动态PHP网页访问过程,以及nginx解析php步骤

    www.example.com | Nginx | 路由到www.example.com/index.php | 加载nginx的fast-cgi模块 | fast-cgi监听127.0.0.1:90 ...

  9. 如何在关闭ssh连接的情况下,让进程继续运行?

    #screen 1 回车后进入Screen子界面,此时putty标题栏会指示处于子界面状态,然后运行你的程序 #应用程序名 1 然后按下Ctrl+A后抬起,然后按下d键,此时切换回主界面,Putty的 ...

  10. 吴恩达课后作业学习1-week4-homework-multi-hidden-layer -2

    参考:https://blog.csdn.net/u013733326/article/details/79767169 希望大家直接到上面的网址去查看代码,下面是本人的笔记 实现多层神经网络 1.准 ...