• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

组织机构代码校验码生成算法(C#版)

原作者: [db:作者] 来自: [db:来源] 收藏 邀请
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace OrganizationCode
{
    class Program
    {
        public static void Main(string[] args)
        {
            string y_bm = "71774346";
            //y_bm = "71774346-9";
            //y_bm = "73767624-0";
            //y_bm = "74549579-X";
            y_bm = "74610229-x";  
            Console.WriteLine(y_bm);
            string bm = Code9(y_bm);
            Console.WriteLine(bm);

        }
        //组织机构代码校验码(验证程序)
        //组织机构代码71774346-9,73767624-0  
        //规定本体代码PDY00001至PDY99999为自定义区,供各系统编制内部组织机构代码使用。
        //自定义区内编制的组织机构代码不作为个系统之间信息交换的依据  
        //组织机构代码管理办法  编制规则  
        //校验码按照以下公式计算:  
        /*C9=11-MOD(∑Ci(i=1→8)×Wi,11) 
        式中: MOD——代表求余函数; 
        i——代表代码字符从左至右位置序号; 
        Ci——代表第i位上的代码字符的值(具体代码字符见附表); 
        C9——代表校验码; 
        Wi——代表第i位上的加权因子,其数值见下表: 
         i=1,2,3,4,5,6,7,8 
        Wi=3,7,9,10,5,8,4,2   
        当C9的值为10时,校验码应用大写的拉丁字母X表示;当C9的值为11时校验码用0表示。
         */
        //代码字符机器处理字符数值  
        // 0 0   1 1  9 9 A 10 B 11  Z 35 
        public static string Code9(string str_in)
        {
            string rbc = "";
            //W权位  
            int[] wArray = new int[] { 3, 7, 9, 10, 5, 8, 4, 2 };
            string str_in_U = str_in.ToUpper();
            char c;
            int zz = 0, z = 0;
            for (int i = 0; i <= 7; i++)
            {
                c = char.Parse(str_in.Substring(i, 1));
                if (c >= 'A' && c <= 'Z')  //A-Z字符
                {
                    z = ((int)c - 55) * wArray[i];
                }
                else if (c >= '0' && c <= '9')  //0-9字符
                {
                    z = int.Parse(c.ToString()) * wArray[i];
                }
                else
                {
                    rbc = "Err不能输入其他字符错误码";
                    return rbc;
                }
                zz += z;
            }
            string C9 = "";
            int jav = 11 - (zz % 11);
            if (jav == 10)
            {
                C9 = "X";
            }
            else if (jav == 11)
            {
                C9 = "0";
            }
            else
            {
                C9 = jav.ToString().Trim(); //删除文本前导空格  
            }
            rbc = str_in.Substring(0, 8) + "-" + C9;//全国组织机构代码8位本体位加一个校验位
            return rbc;
        }
    }
}

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
delphi调用C#写的web服务例子-----------(重点InvRegistry.RegisterInvokeOptions(Typ ...发布时间:2022-07-14
下一篇:
C#模拟HTTPPOST请求发布时间:2022-07-14
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap