swstring.h 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. /************************************************************************
  2. * AUTHOR: NiuJiuRu
  3. * FILENAME: swstring.h
  4. * DESCRIPTION: 字符串操作扩展函数
  5. * NOTE:
  6. * HISTORY:
  7. * 1, [2010-07-05] created by NiuJiuRu
  8. * 2, [2014-01-10] 修改"sw_str_getFieldName()"和"sw_str_getFieldValue()"
  9. 函数
  10. ***********************************************************************/
  11. #ifndef __SWSTRING_H__
  12. #define __SWSTRING_H__
  13. #ifdef __cplusplus
  14. extern "C"
  15. {
  16. #endif
  17. /* 将所有字符转化成小写 */
  18. char *xstrtolower(char *str);
  19. /* 将所有字符转化成大写 */
  20. char *xstrtoupper(char *str);
  21. /* 在一个字符串内, 统计其包含某个给定字符的个数 */
  22. int xstrcharcnt(const char *str, char c);
  23. /* 在一个字符串内, 用一个给定的字符替换一个已存在的字符 */
  24. int xstrcharreplace(char *str, char src, char dst);
  25. /* 是否一个整数字符串 */
  26. bool xstrisint(const char *str);
  27. /* 是否一个十六进制字符串 */
  28. bool xstrishex(const char *str);
  29. /* 是否一个浮点字符串 */
  30. bool xstrisfloat(const char *str);
  31. /* 不区分大小写的比较字符串 */
  32. int xstrcasecmp(const char *s1, const char *s2);
  33. /* 不区分大小写的比较字符串的前n个字符 */
  34. int xstrncasecmp(const char *s1, const char *s2, int n);
  35. /* 不区分大小写的在一个字符串中查找子字符串 */
  36. // mode: 1, "left" - 从字符串的开始位置向后查找; 2, "right" - 从字符串的结束位置向前查找
  37. char *xstrcasestr(const char *str, const char *mode, const char *child);
  38. /* 不区分大小写的在一个字符串中查找字符 */
  39. // mode: 1, "left" - 从字符串的开始位置向后查找; 2, "right" - 从字符串的结束位置向前查找
  40. char *xstrcasechr(const char *str, const char *mode, char c);
  41. /* 获取系统当前的日期时间到字符串 */
  42. // mode: 1, "datetime" - 日期和时间; 2, "datetime(h)" - 日期和时间(精确到毫秒); 3, "date" - 只有日期;
  43. // 4, "time" - 只有时间; 5, "time(h)" - 只有时间(精确到毫秒)
  44. char *xstrgettime(char *str, const char *mode);
  45. /* 改变一个日期时间字符串(单位: 毫秒)的值 */
  46. // mode: 1, "datetime" - 日期和时间; 2, "datetime(h)" - 日期和时间(精确到毫秒); 3, "date" - 只有日期;
  47. // 4, "time" - 只有时间; 5, "time(h)" - 只有时间(精确到毫秒)
  48. char *xstrtimegrow(char *str, const char *mode, int64_t ms);
  49. /* 比较两个日期时间字符串, 并得到它们之间的差值(单位: 毫秒) */
  50. // mode: 1, "datetime" - 日期和时间; 2, "datetime(h)" - 日期和时间(精确到毫秒); 3, "date" - 只有日期;
  51. // 4, "time" - 只有时间; 5, "time(h)" - 只有时间(精确到毫秒)
  52. bool xstrtimecmp(const char *s1, const char *s2, const char *mode, int64_t *interval);
  53. /* 使用Unix时间戳字符串设置系统时间 */
  54. int xsetlocaltime(const char *timestamp);
  55. // Retrieves the number of milliseconds that have elapsed since the system was started
  56. int xgettickcount(unsigned long *tick);
  57. /* 不区分大小写的将一个十六进制字符串转换为它所对应的十六进制数据 */
  58. // 1, 可自动处理"0x"/"0X"前缀、空格、逗号、'\t'、'\r'、'\n'等控制字符
  59. int xstrtohex(const char *str, unsigned char *hex);
  60. /* 从一个十六进制数据缓冲中构建出一个它所对应的十六进制字符串 */
  61. // 1, 可自动添加"0x"/"0X"前缀、空格、逗号等分割符
  62. int xstrfromhex(const unsigned char *hex, int hexCnt, char *str, const char *prefix, const char *split);
  63. /* 不区分大小写的在特定数据格式的Buffer中根据"字段值"设置它所对应的"字段名" */
  64. // 1, Buffer中数据的组成格式为: "n1 = v1"+"定界符"+"n2 = v2"+"定界符"+..."nn = vn"("="号的左边为"字段名",
  65. // 右边为"字段值")
  66. // 2, 可自动识别处理空格、'\t'、'\r'、'\n'等控制字符
  67. bool sw_str_setFieldName(char *buf, int bufSize, char delimiter, const char *name, const char *value,
  68. bool autoAdd, int *varySize);
  69. /* 不区分大小写的在特定数据格式的Buffer中根据"字段值"取得它所对应的"字段名" */
  70. // 1, Buffer中数据的组成格式为: "n1 = v1"+"定界符"+"n2 = v2"+"定界符"+..."nn = vn"("="号的左边为"字段名",
  71. // 右边为"字段值")
  72. // 2, 可自动识别处理空格、'\t'、'\r'、'\n'等控制字符
  73. char *sw_str_getFieldName(const char *buf, int bufSize, char delimiter, char *name, int nameSize, const char *value);
  74. /* 不区分大小写的在特定数据格式的Buffer中根据"字段名"删除该"字段" */
  75. // 1, Buffer中数据的组成格式为: "n1 = v1"+"定界符"+"n2 = v2"+"定界符"+..."nn = vn"("="号的左边为"字段名",
  76. // 右边为"字段值")
  77. // 2, 可自动识别处理空格、'\t'、'\r'、'\n'等控制字符
  78. bool sw_str_delFieldByName(char *buf, int bufSize, char delimiter, const char *name, int *varySize);
  79. /* 不区分大小写的在特定数据格式的Buffer中根据"字段名"设置它所对应的"字段值" */
  80. // 1, Buffer中数据的组成格式为: "n1 = v1"+"定界符"+"n2 = v2"+"定界符"+..."nn = vn"("="号的左边为"字段名",
  81. // 右边为"字段值")
  82. // 2, 可自动识别处理空格、'\t'、'\r'、'\n'等控制字符
  83. bool sw_str_setFieldValue(char *buf, int bufSize, char delimiter, const char *name, const char *value,
  84. bool autoAdd, int *varySize);
  85. /* 不区分大小写的在特定数据格式的Buffer中根据"字段名"取得它所对应的"字段值" */
  86. // 1, Buffer中数据的组成格式为: "n1 = v1"+"定界符"+"n2 = v2"+"定界符"+..."nn = vn"("="号的左边为"字段名",
  87. // 右边为"字段值")
  88. // 2, 可自动识别处理空格、'\t'、'\r'、'\n'等控制字符
  89. char *sw_str_getFieldValue(const char *buf, int bufSize, char delimiter, const char *name, char *value, int valueSize);
  90. /* 不区分大小写的在特定数据格式的Buffer中根据"字段值"删除该"字段" */
  91. // 1, Buffer中数据的组成格式为: "n1 = v1"+"定界符"+"n2 = v2"+"定界符"+..."nn = vn"("="号的左边为"字段名",
  92. // 右边为"字段值")
  93. // 2, 可自动识别处理空格、'\t'、'\r'、'\n'等控制字符
  94. bool sw_str_delFieldByValue(char *buf, int bufSize, char delimiter, const char *value, int *varySize);
  95. #ifdef __cplusplus
  96. }
  97. #endif
  98. #endif /* __SWSTRING_H__ */