Excel生成guid、uuid
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Excel生成guid、uuid相关的知识,希望对你有一定的参考价值。
参考技术A 1、Excel生成guid,uuid 格式:600d65bc-948a-1260-2217-fd8dfeebb1cd2、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的主要内容,如果未能解决你的问题,请参考以下文章