- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在开发一个调用 soap 函数并返回 Diction<string, List<string>>
的 android 应用程序.
响应如下所示:
<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
<s:Body>
<retrieveDatabasesResponse xmlns="http://tempuri.org/">
<retrieveDatabasesResult xmlns:a="http://schemas.microsoft.com/2003/10/Serialization/Arrays" xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>information_schema</a:Key>
<a:Value>
<a:string>CHARACTER_SETS</a:string>
<a:string>COLLATIONS</a:string>
<a:string>COLLATION_CHARACTER_SET_APPLICABILITY</a:string>
<a:string>COLUMNS</a:string>
<a:string>COLUMN_PRIVILEGES</a:string>
<a:string>ENGINES</a:string>
<a:string>EVENTS</a:string>
<a:string>FILES</a:string>
<a:string>GLOBAL_STATUS</a:string>
<a:string>GLOBAL_VARIABLES</a:string>
<a:string>KEY_COLUMN_USAGE</a:string>
<a:string>PARAMETERS</a:string>
<a:string>PARTITIONS</a:string>
<a:string>PLUGINS</a:string>
<a:string>PROCESSLIST</a:string>
<a:string>PROFILING</a:string>
<a:string>REFERENTIAL_CONSTRAINTS</a:string>
<a:string>ROUTINES</a:string>
<a:string>SCHEMATA</a:string>
<a:string>SCHEMA_PRIVILEGES</a:string>
<a:string>SESSION_STATUS</a:string>
<a:string>SESSION_VARIABLES</a:string>
<a:string>STATISTICS</a:string>
<a:string>TABLES</a:string>
<a:string>TABLESPACES</a:string>
<a:string>TABLE_CONSTRAINTS</a:string>
<a:string>TABLE_PRIVILEGES</a:string>
<a:string>TRIGGERS</a:string>
<a:string>USER_PRIVILEGES</a:string>
<a:string>VIEWS</a:string>
<a:string>INNODB_BUFFER_PAGE</a:string>
<a:string>INNODB_TRX</a:string>
<a:string>INNODB_BUFFER_POOL_STATS</a:string>
<a:string>INNODB_LOCK_WAITS</a:string>
<a:string>INNODB_CMPMEM</a:string>
<a:string>INNODB_CMP</a:string>
<a:string>INNODB_LOCKS</a:string>
<a:string>INNODB_CMPMEM_RESET</a:string>
<a:string>INNODB_CMP_RESET</a:string>
<a:string>INNODB_BUFFER_PAGE_LRU</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>boardies_password_manager</a:Key>
<a:Value>
<a:string>alarms</a:string>
<a:string>categories</a:string>
<a:string>passwords</a:string>
<a:string>settings</a:string>
<a:string>users</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>bugs</a:Key>
<a:Value>
<a:string>alarms</a:string>
<a:string>comments</a:string>
<a:string>logfile_history</a:string>
<a:string>platforms</a:string>
<a:string>privileges</a:string>
<a:string>reports</a:string>
<a:string>requested_features</a:string>
<a:string>settings</a:string>
<a:string>short_bulletins</a:string>
<a:string>software</a:string>
<a:string>users</a:string>
<a:string>versions</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>bugs_demo</a:Key>
<a:Value>
<a:string>alarms</a:string>
<a:string>comments</a:string>
<a:string>logfile_history</a:string>
<a:string>platforms</a:string>
<a:string>privileges</a:string>
<a:string>reports</a:string>
<a:string>requested_features</a:string>
<a:string>settings</a:string>
<a:string>software</a:string>
<a:string>users</a:string>
<a:string>versions</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>bugs_old</a:Key>
<a:Value>
<a:string>alarms</a:string>
<a:string>alarms_archive</a:string>
<a:string>comments</a:string>
<a:string>discussions</a:string>
<a:string>message_content</a:string>
<a:string>message_details</a:string>
<a:string>platforms</a:string>
<a:string>reports</a:string>
<a:string>settings</a:string>
<a:string>software</a:string>
<a:string>users</a:string>
<a:string>versions</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>critimon</a:Key>
<a:Value>
<a:string>administrators</a:string>
<a:string>alarms</a:string>
<a:string>android_devices</a:string>
<a:string>app_using_api_version</a:string>
<a:string>available_sdks</a:string>
<a:string>config_groups</a:string>
<a:string>config_items</a:string>
<a:string>config_values</a:string>
<a:string>crash_details</a:string>
<a:string>customer_queries</a:string>
<a:string>development_devices</a:string>
<a:string>generated_monthly_reports</a:string>
<a:string>registered_apps</a:string>
<a:string>sdk_versions</a:string>
<a:string>user_config_groups</a:string>
<a:string>user_config_items_18</a:string>
<a:string>user_config_values</a:string>
<a:string>users</a:string>
<a:string>windows_devices</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>email</a:Key>
<a:Value>
<a:string>alarms</a:string>
<a:string>alarms_archive</a:string>
<a:string>attachments</a:string>
<a:string>config_groups</a:string>
<a:string>config_items</a:string>
<a:string>config_values</a:string>
<a:string>queue</a:string>
<a:string>smtp_auth_users</a:string>
<a:string>smtp_debug_details</a:string>
<a:string>smtp_debug_record</a:string>
<a:string>users</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>email_something</a:Key>
<a:Value>
<a:string>alarms</a:string>
<a:string>attachments</a:string>
<a:string>authenticated_users</a:string>
<a:string>auto_replies</a:string>
<a:string>blacklist</a:string>
<a:string>emailqueue</a:string>
<a:string>logfile_history</a:string>
<a:string>settings</a:string>
<a:string>smtp_debug_details</a:string>
<a:string>smtp_debug_record</a:string>
<a:string>users</a:string>
<a:string>whitelist</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>email_test</a:Key>
<a:Value>
<a:string>alarms</a:string>
<a:string>attachments</a:string>
<a:string>authenticated_users</a:string>
<a:string>auto_replies</a:string>
<a:string>blacklist</a:string>
<a:string>emailqueue</a:string>
<a:string>logfile_history</a:string>
<a:string>settings</a:string>
<a:string>smtp_debug_details</a:string>
<a:string>smtp_debug_record</a:string>
<a:string>users</a:string>
<a:string>whitelist</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>email_user</a:Key>
<a:Value>
<a:string>alarms</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>emailserver</a:Key>
<a:Value>
<a:string>alarms</a:string>
<a:string>attachments</a:string>
<a:string>authenticated_users</a:string>
<a:string>auto_replies</a:string>
<a:string>blacklist</a:string>
<a:string>emailqueue</a:string>
<a:string>logfile_history</a:string>
<a:string>settings</a:string>
<a:string>smtp_debug_details</a:string>
<a:string>smtp_debug_record</a:string>
<a:string>users</a:string>
<a:string>whitelist</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>mysql</a:Key>
<a:Value>
<a:string>columns_priv</a:string>
<a:string>db</a:string>
<a:string>event</a:string>
<a:string>func</a:string>
<a:string>general_log</a:string>
<a:string>help_category</a:string>
<a:string>help_keyword</a:string>
<a:string>help_relation</a:string>
<a:string>help_topic</a:string>
<a:string>host</a:string>
<a:string>ndb_binlog_index</a:string>
<a:string>plugin</a:string>
<a:string>proc</a:string>
<a:string>procs_priv</a:string>
<a:string>proxies_priv</a:string>
<a:string>servers</a:string>
<a:string>slow_log</a:string>
<a:string>tables_priv</a:string>
<a:string>time_zone</a:string>
<a:string>time_zone_leap_second</a:string>
<a:string>time_zone_name</a:string>
<a:string>time_zone_transition</a:string>
<a:string>time_zone_transition_type</a:string>
<a:string>user</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>mysql_server_manager</a:Key>
<a:Value>
<a:string>alarms</a:string>
<a:string>config_groups</a:string>
<a:string>config_items</a:string>
<a:string>config_values</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>performance_schema</a:Key>
<a:Value>
<a:string>cond_instances</a:string>
<a:string>events_waits_current</a:string>
<a:string>events_waits_history</a:string>
<a:string>events_waits_history_long</a:string>
<a:string>events_waits_summary_by_instance</a:string>
<a:string>events_waits_summary_by_thread_by_event_name</a:string>
<a:string>events_waits_summary_global_by_event_name</a:string>
<a:string>file_instances</a:string>
<a:string>file_summary_by_event_name</a:string>
<a:string>file_summary_by_instance</a:string>
<a:string>mutex_instances</a:string>
<a:string>performance_timers</a:string>
<a:string>rwlock_instances</a:string>
<a:string>setup_consumers</a:string>
<a:string>setup_instruments</a:string>
<a:string>setup_timers</a:string>
<a:string>threads</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>software_audit_dev</a:Key>
<a:Value>
<a:string>fault_notes</a:string>
<a:string>faults</a:string>
<a:string>notes</a:string>
<a:string>software</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:KeyValueOfstringArrayOfstringty7Ep6D1>
<a:Key>test</a:Key>
<a:Value>
<a:string>fault_notes</a:string>
<a:string>file_history</a:string>
<a:string>my_table</a:string>
<a:string>stored_connections</a:string>
</a:Value>
</a:KeyValueOfstringArrayOfstringty7Ep6D1>
</retrieveDatabasesResult>
</retrieveDatabasesResponse>
</s:Body>
</s:Envelope>
我正在尝试获取 中元素的计数,这样我就可以循环获取列表,但我尝试过的方法似乎不起作用。
下面是我使用的代码
private void processRetrievedDatabase(SoapObject soapResult)
{
int i = 0;
int j = 0;
SoapObject rootArray = ((SoapObject)soapResult.getProperty(0));
SoapObject dbArray = ((SoapObject)rootArray.getProperty(0));
int dbCount = dbArray.getPropertyCount();
ArrayList<String> databases = new ArrayList<String>();
while (i < dbCount)
{
if (i % 2 == 0)
{
databases.add(dbArray.getPropertyAsString(i));
Log.d(TAG, dbArray.getPropertyAsString(i));
}
else
{
SoapObject tablesArray = ((SoapObject)dbArray.getProperty(i));
int tableCount = tablesArray.getPropertyCount();
while (j < tableCount)
{
Log.d(TAG, tablesArray.getPropertyAsString(j));
j++;
}
}
i++;
}
下面是我在 logcat 中得到的内容
12-04 19:52:49.480: D/Soap Manager(6204): anyType{Key=information_schema; Value=anyType{string=CHARACTER_SETS; string=COLLATIONS; string=COLLATION_CHARACTER_SET_APPLICABILITY; string=COLUMNS; string=COLUMN_PRIVILEGES; string=ENGINES; string=EVENTS; string=FILES; string=GLOBAL_STATUS; string=GLOBAL_VARIABLES; string=KEY_COLUMN_USAGE; string=PARAMETERS; string=PARTITIONS; string=PLUGINS; string=PROCESSLIST; string=PROFILING; string=REFERENTIAL_CONSTRAINTS; string=ROUTINES; string=SCHEMATA; string=SCHEMA_PRIVILEGES; string=SESSION_STATUS; string=SESSION_VARIABLES; string=STATISTICS; string=TABLES; string=TABLESPACES; string=TABLE_CONSTRAINTS; string=TABLE_PRIVILEGES; string=TRIGGERS; string=USER_PRIVILEGES; string=VIEWS; string=INNODB_BUFFER_PAGE; string=INNODB_TRX; string=INNODB_BUFFER_POOL_STATS; string=INNODB_LOCK_WAITS; string=INNODB_CMPMEM; string=INNODB_CMP; string=INNODB_LOCKS; string=INNODB_CMPMEM_RESET; string=INNODB_CMP_RESET; string=INNODB_BUFFER_PAGE_LRU; }; }
12-04 19:53:01.896: D/Soap Manager(6204): anyType{Key=information_schema; Value=anyType{string=CHARACTER_SETS; string=COLLATIONS; string=COLLATION_CHARACTER_SET_APPLICABILITY; string=COLUMNS; string=COLUMN_PRIVILEGES; string=ENGINES; string=EVENTS; string=FILES; string=GLOBAL_STATUS; string=GLOBAL_VARIABLES; string=KEY_COLUMN_USAGE; string=PARAMETERS; string=PARTITIONS; string=PLUGINS; string=PROCESSLIST; string=PROFILING; string=REFERENTIAL_CONSTRAINTS; string=ROUTINES; string=SCHEMATA; string=SCHEMA_PRIVILEGES; string=SESSION_STATUS; string=SESSION_VARIABLES; string=STATISTICS; string=TABLES; string=TABLESPACES; string=TABLE_CONSTRAINTS; string=TABLE_PRIVILEGES; string=TRIGGERS; string=USER_PRIVILEGES; string=VIEWS; string=INNODB_BUFFER_PAGE; string=INNODB_TRX; string=INNODB_BUFFER_POOL_STATS; string=INNODB_LOCK_WAITS; string=INNODB_CMPMEM; string=INNODB_CMP; string=INNODB_LOCKS; string=INNODB_CMPMEM_RESET; string=INNODB_CMP_RESET; string=INNODB_BUFFER_PAGE_LRU; }; }
我几乎已经完成了,但它应该打印出数据库,然后是 log cat 中的所有表并重复,但由于某种原因它只打印第一个数据库及其表。
所以在我上面的例子中,它应该打印
information_schema
CHARACTER_SETS
COLLATIONS
COLLATION_CHARACTER_SET_APPLICABILITY
etc
etc
boardies_password_manager
alarms
categories
passwords
etc
etc
但我只得到 information_schema 及其表而不是数据库的其余部分
感谢您提供的任何帮助。
最佳答案
如果我理解正确的话,它只打印第一个数据库,因为在为下一个表开始循环之前,j
变量没有重置为 0。所以,else block 应该是这样的:
else
{
SoapObject tablesArray = ((SoapObject)dbArray.getProperty(i));
int tableCount = tablesArray.getPropertyCount();
// j should reset to 0
j = 0;
while (j < tableCount)
{
Log.d(TAG, tablesArray.getPropertyAsString(j));
j++;
}
}
或者您可能需要这样的 for 循环(我喜欢这种方式,因为它比 while 更简单、更清晰):
private void processRetrievedDatabase(SoapObject soapResult)
{
SoapObject rootArray = ((SoapObject)soapResult.getProperty(0));
SoapObject dbArray = ((SoapObject)rootArray.getProperty(0));
int dbCount = dbArray.getPropertyCount();
ArrayList<String> databases = new ArrayList<String>();
for(int i = 0; i < dbCount; i++){
if (i % 2 == 0)
{
databases.add(dbArray.getPropertyAsString(i));
Log.d(TAG, dbArray.getPropertyAsString(i));
}
else
{
SoapObject tablesArray = ((SoapObject)dbArray.getProperty(i));
int tableCount = tablesArray.getPropertyCount();
for(int j = 0; j < tableCount; j++){
Log.d(TAG, tablesArray.getPropertyAsString(j));
}
}
}
}
关于android - 使用 KSoap2 从 Soap 接收和处理 Dictionary<string, List<string>>,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20385394/
我正在用 Python (2.6) 编写一个应用程序,需要我使用字典作为数据存储。 我很好奇拥有一个大字典是否更节省内存,或者将其分解为许多(很多)较小的字典,然后拥有一个包含对所有较小字典的引用的“
Convert this [ "Cat" : ["A" : 1, "B": 2], "Mat" : ["C" : 3, "D": 4] ] Into [ "A" : 1,
有什么很酷的快速方法可以让两个字典创建第三个字典,以内连接方式将第一个字典的键映射到第二个字典的值? Dictionary dic1 = new Dictionary {{a1,b1},{a2,b2}
我希望将字典相互嵌套,以便容纳 block 的 xy 坐标。所以我会 IDictionary, IDictionary> 键 Dictionary 包含列、行组合,而值 Dictionary 包含 x
在 C# 中,我需要将数据保存在字典对象中,如下所示: Dictionary> MyDict = new Dictionary>(); 现在我意识到,在某些情况下我需要一些其他(不是字典类的)
第一个Dictionary就像 Dictionary ParentDict = new Dictionary(); ParentDict.Add("A_1", "1")
我似乎无法理解这个问题。我需要使用 LINQ 按内部字典的值对字典进行排序。有什么想法吗? 最佳答案 你的意思是你想要所有的值,按内部值排序? from outerPair in outer from
我想建模一个模式,其中响应是字典: { 'id1': { 'type': 'type1', 'active': true, }, 'id2': { 'type':
我有以下代码要添加或更新(如果已经存在)dict()-dict 中的值: if id not in self.steps: self.steps[ id ] = step else:
我有一个包含字典的 Swift 字典,我想使用存储的属性来访问键值: var json = [NSObject:AnyObject]() var title: String { get
我想创建一个 Dictionary>结构,我想提供一个 IEqualityComparer在包含 APerson 的second 字典中作为关键 如果我只有内部字典,那就是 var f = new D
我有一个集合,其中包含如下文档:文档 1: { "company": "ABC" "application": { "app-1": {"earning_from_src_A": 50,
我正在快速学习。 我发现 dictionary 就像 hash 用于 PHP 或其他一些语言。 那我怎么制作dictionary的dictionary呢?? 我有这样的数据 key:J name:jh
这个问题在这里已经有了答案: Explode a dict - Get all combinations of the values in a dictionary (2 个答案) 关闭 5 个月前
我是编程新手,所以如果我的问题看起来很愚蠢,我很抱歉。我想问一下有没有办法从 Multi.Dictionary 返回key当我有值(value)? 这是我的代码: Dim myDict Set myD
我试图找出标准 Ada 库是否配备了“字典”类型(我的意思是:一种以 格式存储值的数据结构,我可以从中检索 value 使用相应的唯一 key)。 这样的数据结构存在吗?如果是这样,有人可以提供一个
我究竟做错了什么?根据我的测试,objDic.exists 永远不会给出 False! dim objDic set objDic = createobject("scripting.
我想创建一个复合类型,其中包含一个字典作为其命名字段之一。但是明显的语法不起作用。我敢肯定有一些我不明白的基本原理。下面是一个例子: type myType x::Dict() end Jul
julia> hotcell2vocab = Dict([(cell, i-1+vocab_start) for (i,cell) in enumerate(h
我有一个简单的问题:我对 Dictionary.Value 集合进行了很多次迭代,这让我很烦,我必须调用 .ToList() 然后才能调用 .ForEach(),因为它似乎没有可枚举的Dictiona
我是一名优秀的程序员,十分优秀!