Excel生成guid、uuid

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Excel生成guid、uuid相关的知识,希望对你有一定的参考价值。

参考技术A 1、Excel生成guid,uuid 格式:600d65bc-948a-1260-2217-fd8dfeebb1cd

2、Excel生成guid,uuid 格式:600d65bc948a12602217fd8dfeebb1cd

3、Excel生成guid,uuid 格式:4E3B14BB-ECF3-7B2E-A5A2-FE6E1A52DE6A

4、Excel生成guid,uuid 格式:4E3B14BBECF37B2E-A5A2FE6E1A52DE6A

如何快速生成 UUID GUID

  通用的GUID的结构如下

  typedef struct _GUID
  DWORD Data1;
  WORD Data2;
  WORD Data3;
  BYTE Data4[8];
   GUID;

  举一个例子:
  假设一个GUID的格式是这样的 6B29FC40-CA47-1067-B31D-00DD010662DA

  其中Data1 是32位,可以看做8个四位十六进制数,对应于上面的6B29FC40

  其中Data2 是16位,可以看做4个四位十六进制数,对应于上面的CA47
  其中Data3 是16位,可以看做4个四位十六进制数,对应于上面的1067
  其中Data4 比较特殊,是8个字节也就可以看做16个四位十六进制数
  取其Data4[0],Data4[1]来组成4个四位十六进制数,对应于上面的B31D
  取其Data4[2],Data4[3]来组成4个四位十六进制数,对应于上面的00DD
  取其Data4[4],Data4[5]来组成4个四位十六进制数,对应于上面的0106
  取其Data4[6],Data4[7]来组成4个四位十六进制数,对应于上面的62DA

  *注意:四位十六进制数对应一个GUID字符。

  在Windows下提供了一个函数可以生成一个GUID。需要使用的头文件 "objbase.h",需要链接的库ole32.lib。
  HRESULT CoCreateGuid(GUID * pguid);

  在Linux下首先需要下载到相应的库文件和头文件
  如果是Debian用户可以方便的通过apt命令来获取相关资源。
  apt-get install uuid-dev

  安装完成后会发现
  在/usr/include/ 下有一个uuid文件夹,其中则包含了uuid.h头文件。
  在/usr/lib/ 下有几个libuuid*的链接库文件,包括静态和动态链接库。

  打开uuid.h你会发现有一个uuid_generate(uuid_t out) 的函数声明。我们可以通过调用这个函数来生成UUID。
  uuid_generate(reinterpret_cast<unsigned char *>(&guid));

  生成GUID是不是很简单!是的,因为生成的算法不用我们去实现,我们是站在前人的肩膀所以我们要感谢他们。

  下面给出一个WINDOWS和LINUX下通用的程序。

  // uuid_test.cpp
  #include <string>
  #include <stdio.h>
  #include <iostream>
  #include "uuid_test.hpp"

  #ifdef WIN32
  #include <objbase.h>
  #else
  #include <uuid/uuid.h>
  #endif

  using namespace std;
  namespace ChinuxTeam
  
  GUID CreateGuid()
  
  GUID guid;
  #ifdef WIN32
  CoCreateGuid(&guid);
  #else
  uuid_generate(reinterpret_cast<unsigned char *>(&guid));
  #endif
  return guid;
  

  std::string GuidToString(const GUID &guid)
  
  char buf[64] = 0;
  #ifdef __GNUC__
  snprintf(
  #else // MSVC
  _snprintf_s(
  #endif
  buf,
  sizeof(buf),
  "%08X-%04X-%04X-%02X%02X-%02X%02X%02X%02X%02X%02X",
  guid.Data1, guid.Data2, guid.Data3,
  guid.Data4[0], guid.Data4[1],
  guid.Data4[2], guid.Data4[3],
  guid.Data4[4], guid.Data4[5],
  guid.Data4[6], guid.Data4[7]);
  return std::string(buf);
  
  

  对应的头文件
  // uuid_test.hpp"

  #include <string>
  #include <stdio.h>
  #include <iostream>

  typedef struct _GUID
  
  unsigned long Data1;
  unsigned short Data2;
  unsigned short Data3;
  unsigned char Data4[8];
   GUID, UUID;

  namespace ChinuxTeam
  
  GUID CreateGuid();
  std::string GuidToString(const GUID &guid);
  // namespace ChinuxTeam

  最后一个 GuidToString()稍微解释一下,作用就是把GUID以固定的格式输出到标准string字符串中,
  根据编译器的不同调用分别调用了不同的字符串打印函数。

  另外附一个简单的测试函数
  #include <string>
  #include <stdio.h>
  #include <iostream>

  #ifdef WIN32
  #include "objbase.h"
  #else

  typedef struct _GUID
  
  unsigned long Data1;
  unsigned short Data2;
  unsigned short Data3;
  unsigned char Data4[8];
   GUID, UUID;

  #endif

  namespace ChinuxTeam
  GUID CreateGuid();
  std::string GuidToString(const GUID &guid);
  

  运行后会生成一个GUID并打印到标准输出的控制台上。
参考技术A win7及以上版本,最简单的方法是这样:
powershell里输入下面命令,100个guid就出来了,要多少个,把100改成多少就行,注意1和100之间是2个点哦
1..100|%new-guid

以上是关于Excel生成guid、uuid的主要内容,如果未能解决你的问题,请参考以下文章

excel中 自动生成UUID

批量生成QRcode

如何快速生成 UUID GUID

mysql 生成UUID() 即 ORACLE 中的guid()函数

跨平台生成GUID/UUID

loadrunner生成随机uuid的方法