每个人眼中都有一个哈姆雷特

每个人眼中都有一个哈姆雷特


                                                                                                                                ---记我的根级别数据无效


      一千个人眼中有一千个哈姆雷特!看到的是同样一个哈姆雷特,但每个人眼中都会有自己的哈姆雷特,所以平时我们开发中,很多时候即使抛出同样的异常,也往往可能是不同的原因导致的!当我们运用我们以往的经验没有解决这个问题时,那么我们还是老老实实、心平气和的慢慢查找、琢磨问题所在以及解决方法。
     上周开发中遇到了著名的“Data at the root level is invalid. Line 1, position 1.”
               
       代码大意

            string xml = st.Split('☎')[0 ];
            System.Xml.XmlDocument doc = new
System.Xml.XmlDocument();
            doc.LoadXml(xml);

        在网查找了各种解决方案但是都于事无补
        1. 去掉字符串两端的空格

           

            string xml = st.Split('☎')[0 ].Trim();
            System.Xml.XmlDocument doc = new
System.Xml.XmlDocument();
            doc.LoadXml(xml);

        2. 将LoadXml改为Load

           

            string xml = st.Split('☎')[0 ].Trim();
            using (System.IO.StringReader sr = new
System.IO.StringReader(xml))
            {
                System.Xml.XmlDocument doc = new
System.Xml.XmlDocument();
                doc.Load(sr);
                sr.Close();
            }

        3. 改变xml的编码为utf-8

           

            string xml = st.Split('☎')[0 ];
            byte[] bytes =
Encoding.UTF8.GetBytes(xml);
            using (MemoryStream ms = new
MemoryStream(bytes))
            {
                using (StreamReader sr = new
StreamReader(ms, Encoding.UTF8))
                {
                    XmlDocument doc = new
XmlDocument();
                    doc.Load(sr);
                    sr.Close();
                }
                ms.Close();
            }

          最后实在想不通哪里的问题,后来想了想是不是因为xml被编码转义的问题(由于某种原因xml字符串需要编码),结果就是这个原因导致的!

        

            string xml = "<book>jbpm深入解析</book>" ;
            xml = xml.Replace("&lt;", "<").Replace("&gt;", ">"
);
            System.Xml.XmlDocument doc = new
System.Xml.XmlDocument();
            doc.LoadXml(xml);


      以上列举的代码实例都有解决问题的成功案例,这里一一列举是为了说明同一个错误可能由不同的原因导致的;同时可能这个错误的排查在我给出的代码实例中很好解决,但是在比较大的项目中就不那么容易了,所以很多时候同样的错误,往往是不同的原因导致的,需要我们耐心的分析解决!

好的,以下是一个简单的 Python 代码示例,用于统计《哈姆雷特》中出现最频繁的前十个人物: ```python import string # 打开文本文件并读取内容 with open('hamlet.txt', 'r') as f: text = f.read() # 将所有单词转换为小写,并且去除文本中的标点符号和换行符 text = text.lower().translate(str.maketrans('', '', string.punctuation + '\n')) # 将文本分割成单个单词 words = text.split() # 创建一个空字典用于存储每个人物出现的次数 character_count = {} # 定义人物列表 characters = ['hamlet', 'claudius', 'gertrude', 'polonius', 'horatio', 'ophelia', 'laertes', 'rosencrantz', 'guildenstern', 'fortinbras'] # 遍历所有单词,统计每个人物出现的次数 for word in words: if word in characters: if word not in character_count: character_count[word] = 1 else: character_count[word] += 1 # 对人物出现次数进行排序 sorted_characters = sorted(character_count.items(), key=lambda x: x[1], reverse=True) # 打印出现最频繁的前十个人物 for character, count in sorted_characters[:10]: print(f"{character}: {count}") ``` 这个代码会将文本中的所有单词转换为小写,并且去除标点符号和换行符。然后它会遍历所有单词,统计每个人物出现的次数,并将结果存储在一个字典中。接着,代码会对人物出现次数进行排序,并打印出现最频繁的前十个人物。请确保你已经在代码中指定正确的文本文件路径。需要注意的是,可能会有一些单词与人物名称相同,但并不是人物名称,因此在实际应用中需要进行一些额外的处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值